Maven,MyBatis


Maven

完成一个java项目,需要做哪些工作

1.分析项目要做什么,知道项目有哪些组成部分。
2.设计项目,通过哪些步骤,使用哪些技术。需要多少人, 多长的时间。
3.组建团队,招人, 购置设备,服务器, 软件, 笔记本。
4.开发人员写代码。 开发人员需要测试自己写代码。 重复多次的工作。
5.测试人员,测试项目功能是否符合要求。
测试开发人员提交代码-如果测试有问题–需要开发人员修改–在提交代码给测试–测试人员在测试代码-如果还有问题-在交给开发人员-开发人员在提交-在测试
直到测试代码通过。

需要改进项目的开发和管理,需要maven

​ 1)maven可以管理jar文件
​ 2)自动下载jar和他的文档,源代码
​ 3)管理jar直接的依赖, a.jar需要b.jar , maven会自动下载b.jar
​ 4)管理你需要的jar版本
​ 5)帮你编译程序,把java编译为class
​ 6)帮你测试你的代码是否正确。
​ 7)帮你打包文件,形成jar文件,或者war文件
​ 8)帮你部署项目

构建: 项目的构建。

构建是面向过程的,就是一些步骤,完成项目代码的编译,测试,运行,打包,部署等等。
maven支持的构建包括有:

  1. 清理, 把之前项目编译的东西删除掉,为新的编译代码做准备。

  2. 编译, 把程序源代码编译为执行代码, java-class文件。批量的,maven可以同时把成千上百的文件编译为class。

  3. 测试, maven可以执行测试程序代码,验证你的功能是否正确。批量的,maven同时执行多个测试代码,同时测试很多功能。

  4. 报告, 生成测试结果的文件, 测试通过没有。

  5. 打包, 把你的项目中所有的class文件,配置文件等所有资源放到一个压缩文件中。这个压缩文件就是项目的结果文件, 通常java程序,压缩文件是jar扩展名的。对于web应用,压缩文件扩展名是.war

  6. 安装, 把5中生成的文件jar,war安装到本机仓库

  7. 部署, 把程序安装好可以执行。

maven核心概念

①POM : 一个文件 名称是pom.xml , pom翻译过来叫做项目对象模型。
maven把一个项目当做一个模型使用。控制maven构建项目的过程,管理jar依赖。

②约定的目录结构 : maven项目的目录和文件的位置都是规定的。

③坐标 : 是一个唯一的字符串,用来表示资源的。

④依赖管理 : 管理你的项目可以使用jar文件

⑤仓库管理(了解) :你的资源存放的位置

⑥生命周期 (了解) : maven工具构建项目的过程,就是生命周期。
⑦插件和目标(了解):执行maven构建的时候用的工具是插件
⑧继承
⑨聚合

maven工具的安装和配置。

1)需要从maven的官网下载maven的安装包 apache-maven-3.3.9-bin.zip
2)解压安装包,解压到一个目录,非中文目录。
子目录 bin :执行程序,主要是mvn.cmd
conf :maven工具本身的配置文件 settings.xml
3)配置环境变量
在系统的环境变量中,指定一个M2_HOME的名称, 指定它的值是maven工具安装目录,bin之前的目录

M2_HOME=D:\work\maven_work\apache-maven-3.3.9

再把M2_HOME加入到path之中,在所有路径之前加入 %M2_HOME%\bin;

4)验证,新的命令行中,执行mvn -v

注意:需要配置JAVA_HOME ,指定jdk路径

C:\Users\Administrator>mvn -v
出现如下内容,maven安装,配置正确。
Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-11T00:41:4
Maven home: D:\work\maven_work\apache-maven-3.3.9
Java version: 1.8.0_40, vendor: Oracle Corporation
Java home: C:\java\JDK8-64\jre
Default locale: zh_CN, platform encoding: GBK
OS name: “windows 7”, version: “6.1”, arch: “amd64”, family: “dos”

maven约定的目录结构

约定是大家都遵循的一个规则。

每一个maven项目在磁盘中都是一个文件夹(项目-Hello)
Hello/
—/src
——/main #放你主程序java代码和配置文件
———-/java #你的程序包和包中的java文件
———-/resources #你的java程序中要使用的配置文件

——/test #放测试程序代码和文件的(可以没有)
———-/java #测试程序包和包中的java文件
———-/resources #测试java程序中要使用的配置文件

—/pom.xml #maven的核心文件(maven项目必须有)

2.疑问: mvn compile 编译src/main目录下的所有java文件。
1)为什么要下载
maven工具执行的操作需要很多插件(java类–jar文件)完成的
2)下载了什么
jar文件–叫做插件–插件是完成某些功能

3)下载的东西存放到哪里了。
默认仓库(本机仓库):
C:\Users\(登录操作系统的用户名)Administrator.m2\repository

Downloading:

https://repo.maven.apache.org/maven2/org/apache/maven/maven-plugin-parameter-documenter-2.0.9.pom

https://repo.maven.apache.org :中央仓库的地址

执行mvn compile, 结果是在项目的根目录下生成target目录(结果目录),maven编译的java程序,最后的class文件都放在target目录中。

设置本机存放资源的目录位置(设置本机仓库):

  1. 修改maven的配置文件, maven安装目录/conf/settings.xml

  2. 修改

    1
    <localRepository> 

    指定你的目录(不要使用中文目录)

仓库

1)仓库是什么: 仓库是存放东西的, 存放maven使用的jar 和 我们项目使用的jar

maven使用的插件(各种jar)

我项目使用的jar(第三方的工具)

2)仓库的分类

本地仓库, 就是你的个人计算机上的文件夹,存放各种jar
远程仓库, 在互联网上的,使用网络才能使用的仓库
①:中央仓库,最权威的, 所有的开发人员都共享使用的一个集中的仓库,
https://repo.maven.apache.org :中央仓库的地址
②:中央仓库的镜像:就是中央仓库的备份, 在各大洲,重要的城市都是镜像。

③:私服,在公司内部,在局域网中使用的, 不是对外使用的。

3)仓库的使用,maven仓库的使用不需要人为参与。
开发人员需要使用mysql驱动—>maven首先查本地仓库—>私服—>镜像—>中央仓库

pom

项目对象模型,是一个pom.xml文件
1)坐标:唯一值, 在互联网中唯一标识一个项目的

1
2
3
<groupId>公司域名的倒写</groupId>
<artifactId>自定义项目名称</artifactId>
<version>自定版本号</version>

https://mvnrepository.com/ 搜索使用的中央仓库, 使用groupId 或者 artifactId作为搜索条件

2) packaging: 打包后压缩文件的扩展名,默认是jar ,web应用是war
packaging 可以不写, 默认是jar

依赖

dependencies 和dependency ,相当于是 java代码中import

你的项目中要使用的各种资源说明, 比如要使用mysql驱动

1
2
3
4
5
6
7
8
<dependencies>
<!--依赖 java代码中 import -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.9</version>
</dependency>
</dependencies>

properties:设置属性

build : maven在进行项目的构建时, 配置信息,例如指定编译java代码使用的jdk的版本等

maven生命周期, maven的命令,maven的插件

  • maven的生命周期:就是maven构建项目的过程,清理,编译,测试,报告,打包,安装,部署。
  • maven的命令:maven独立使用,通过命令,完成maven的生命周期的执行。maven可以使用命令,完成项目的清理,编译,测试等等。
  • maven的插件: maven命令执行时,真正完成功能的是插件,插件就是一些jar文件, 一些类。

单元测试(测试方法)

用的是junit, junit是一个专门测试的框架(工具)。

  • junit测试的内容: 测试的是类中的方法, 每一个方法都是独立测试的。方法是测试的基本单位(单元)。
  • maven借助单元测试,批量的测试你类中的大量方法是否符合预期的。

使用步骤

  1. 加入依赖,在pom.xml加入单元测试依赖
1
2
3
4
5
6
7
 	 <!-- 单元测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
  1. 在maven项目中的src/test/java目录下,创建测试程序。
    推荐的创建类和方法的提示:

    1. 测试类的名称 是Test + 你要测试的类名

    2. 测试的方法名称 是:Test + 方法名称

​ 例如你要测试HelloMaven ,
​ 创建测试类 TestHelloMaven

1
2
3
4
 @Test
public void testAdd(){
测试HelloMaven的add方法是否正确
}

其中testAdd叫做测试方法,它的定义规则

  • 方法是public的,必须的
  • 方法没有返回值, 必须的
  • 方法名称是自定义的,推荐是Test + 方法名称
  • 在方法的上面加入 @Test
  1. mvn compile
    编译main/java/目录下的java 为class文件, 同时把class拷贝到 target/classes目录下面。

    把main/resources目录下的所有文件 都拷贝到target/classes目录下。

在idea中设置maven

idea中内置了maven ,一般不使用内置的, 因为用内置修改maven的设置不方便。
使用自己安装的maven, 需要覆盖idea中的默认的设置。让idea指定maven安装位置等信息

配置的入口

①:配置当前工程的设置, file–settings —Build, Excution,Deployment–Build Tools
–Maven
Maven Home directory: maven的安装目录
User Settings File : 就是maven安装目录conf/setting.xml配置文件
Local Repository : 本机仓库的目录位置

​ –Build Tools–Maven–Runner
​ VM Options : archetypeCatalog=internal
​ JRE: 你项目的jdk

​ archetypeCatalog=internal , maven项目创建时,会联网下载模版文件,
​ 比较大, 使用-DarchetypeCatalog=internal,不用下载, 创建maven项目速度快。

②:配置以后新建工程的设置, file–other settings–Settings for New Project

使用模版创建项目

1)maven-archetype-quickstart : 普通的java项目
2)maven-archetype-webapp : web工程

依赖范围

使用scope表示。
scope的值有 compile, test, provided ,默认是compile
scope:表示依赖使用的范围,也就是在maven构建项目的那些阶段中起作用。
maven构建项目 编译, 测试 ,打包, 安装 ,部署 过程(阶段)

例:

1
2
3
4
5
6
7
<!-junit的依赖范围是 test->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
1
2
3
4
5
<dependency>
<groupId>a</groupId>
<artifactId>b</artifactId> b.jar
<version>4.11</version>
</dependency>
1
2
3
4
5
6
 <dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version> servlet.jar
<scope>provided</scope> 提供者
</dependency>

在写项目的中的用到的所有依赖(jar ) ,必须在本地仓库中有。
没有必须通过maven下载, 包括provided的都必须下载。

你在servlet需要继承HttpServlet( provided) , 你使用的HttpServlet是maven仓库中的。

当写好的程序放到 tomat服务器中运行时, 此时程序中不包含servlet的jar,因为tomcat提供了 servlet的.jar。

maven常用操作

maven的属性设置

1
<properties> 设置maven的常用属性

maven的全局变量

自定义的属性:

1.在 通过自定义标签声明变量(标签名就是变量名)
2.在pom.xml文件中的其它位置,使用 ${标签名} 使用变量的值

自定义全局变量一般是定义依赖的版本号, 当你的项目中要使用多个相同的版本号,先使用全局变量定义, 在使用${变量名}。

资源插件

1
2
3
4
5
6
7
8
9
10
11
12
13
 <build>
<resources>
<resource>
<directory>src/main/java</directory><!--所在的目录-->
<includes><!--包括目录下的.properties,.xml 文件都会扫描到-->
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<!—filtering 选项 false 不启用过滤器, *.property 已经起到过滤的作用了 -->
<filtering>false</filtering>
</resource>
</resources>
</build>

默认没有使用resources的时候, maven执行编译代码时, 会把src/main/resource目录中的文件拷贝到target/classes目录中。

Maven

MyBatis

三层架构

  • 界面层: 和用户打交道的, 接收用户的请求参数, 显示处理结果的。(jsp ,html ,servlet)
  • 业务逻辑层: 接收了界面层传递的数据,计算逻辑,调用数据库,获取数据
  • 数据访问层: 就是访问数据库, 执行对数据的查询,修改,删除等等的。

三层对应的包

  • 界面层: controller包 (servlet)
  • 业务逻辑层: service 包(XXXService类)
  • 数据访问层: dao包(XXXDao类)

三层中类的交互

用户使用界面层–> 业务逻辑层—>数据访问层(持久层)–>数据库(mysql)

三层对应的处理框架

  • 界面层—servlet—springmvc(框架)
  • 业务逻辑层—service类–spring(框架)
  • 数据访问层—dao类–mybatis(框架)

框架

  • 框架是一个模版:

    1. 规定了好一些条款,内容。
    2. 加入自己的东西。
  • 框架是一个模块

    1. 框架中定义好了一些功能。这些功能是可用的。
    2. 可以加入项目中自己的功能, 这些功能可以利用框架中写好的功能。
  • 框架是一个软件,半成品的软件,定义好了一些基础功能, 需要加入你的功能就是完整的。

  • 基础功能是可重复使用的,可升级的。

框架特点:

  1. 框架一般不是全能的, 不能做所有事情。
  2. 框架是针对某一个领域有效。 特长在某一个方面,比如mybatis做数据库操作强,但是他不能做其它的。
  3. 框架是一个软件。

mybatis框架

一个框架,早期叫做ibatis, 代码在github。
mybatis是 MyBatis SQL Mapper Framework for Java (sql映射框架)

  • sql mapper :sql映射
    可以把数据库表中的一行数据 映射为 一个java对象。
    一行数据可以看做是一个java对象。操作这个对象,就相当于操作表中的数据

  • Data Access Objects(DAOs) : 数据访问 , 对数据库执行增删改查。

mybatis提供了哪些功能:

  1. 提供了创建Connection ,Statement, ResultSet的能力 ,不用开发人员创建这些对象了。

  2. 提供了执行sql语句的能力, 不用你执行sql。

  3. 提供了循环sql, 把sql的结果转为java对象, List集合的能力。

    1
    2
    3
    4
    5
    6
    7
    8
    while (rs.next()) {
    Student stu = new Student();
    stu.setId(rs.getInt("id"));
    stu.setName(rs.getString("name"));
    stu.setAge(rs.getInt("age"));
    //从数据库取出数据转为 Student 对象,封装到 List 集合
    stuList.add(stu);
    }
  4. 提供了关闭资源的能力,不用手动关闭Connection, Statement, ResultSet

  5. 流程: 开发人员提供sql语句–mybatis处理sql—开发人员得到List集合或java对象(表中的数据)

总结:

  • mybatis是一个sql映射框架,提供的数据库的操作能力。增强的JDBC,
  • 使用mybatis让开发人员集中精神写sql就可以了,不必关心Connection,Statement,ResultSet的创建,销毁,sql的执行。

主要类的介绍

Resources:

mybatis中的一个类, 负责读取主配置文件

1
InputStream in = Resources.getResourceAsStream("mybatis.xml");

SqlSessionFactoryBuilder :

创建SqlSessionFactory对象,

1
2
3
 SqlSessionFactoryBuilder builder  = new SqlSessionFactoryBuilder();
//创建SqlSessionFactory对象
SqlSessionFactory factory = builder.build(in);

SqlSessionFactory :

接口 , 接口实现类: DefaultSqlSessionFactory

重量级对象, 程序创建一个对象耗时比较长,使用资源比较多。
在整个项目中,有一个就够了。

作用:

获取SqlSession对象。SqlSession sqlSession = factory.openSession();

openSession()方法说明:

  1. openSession() :无参数的, 获取是非自动提交事务的SqlSession对象。
  2. openSession(boolean): openSession(true) 获取自动提交事务的SqlSession。
  3. openSession(false) 非自动提交事务的SqlSession对象

SqlSession:

SqlSession接口 :定义了操作数据的方法 例如 selectOne() ,selectList() ,insert(),update(), delete(), commit(), rollback()
SqlSession接口的实现类DefaultSqlSession。

使用要求:

SqlSession对象不是线程安全的,需要在方法内部使用, 在执行sql语句之前,使用openSession()获取SqlSession对象。

在执行完sql语句后,需要关闭它,执行SqlSession.close(). 这样能保证他的使用是线程安全的。

动态代理:

使用SqlSession.getMapper(dao接口.class) 获取这个dao接口的对象。

传入参数:

从java代码中把数据传入到mapper文件的sql语句中。

parameterType :

写在mapper文件中的 一个属性。 表示dao接口中方法的参数的数据类型。
例如StudentDao接口

1
public Student  selectStudentById(Integer id) 

传入一个简单类型的参数:

简单类型: mybatis把java的基本数据类型和String都叫简单类型。在mapper文件获取简单类型的一个参数的值,使用 #{任意字符}

接口:public Student selectStudentById(Integer id)

1
mapper:select id,name, email,age from student where id=#{studentId}

传入多个参数

使用@Param命名参数
接口 :

1
public List<Student> selectMulitParam(@Param("myname") String name, @Param("myage") Integer age)

使用 @Param(“参数名”) String name

mapper文件:

1
2
3
<select>
select * from student where name=#{myname} or age=#{myage}
</select>

传入多个参数,使用java对象

语法 #{属性名}

vo: value object , 放一些存储数据的类。比如说 提交请求参数, name ,age
现在想把name ,age 传给一个service 类。

vo: view object , 从servlet把数据返回给浏览器使用的类,表示显示结果的类。

pojo: 普通的有set, get方法的java类。 普通的java对象

​ Servlet — StudentService( addStudent( MyParam param) )

entity(domain域): 实体类, 和数据库中的表对应的类,

#和$

1
select id,name, email,age from student where id=#{studentId}

#的结果: select id,name, email,age from student where id=?

1
select id,name, email,age from student where id=${studentId}

$的结果:select id,name, email,age from student where id=1001

1
String sql="select id,name, email,age from student where id=" + "1001";

使用的Statement对象执行sql, 效率比PreparedStatement低。

$:可以替换表名或者列名, 能保证数据安全时(防止SQL注入),可以使用$。

# 和 $区别

  1. #使用 ?在sql语句中做站位的, 使用PreparedStatement执行sql,效率高。
  2. #能够避免sql注入,更安全。
  3. $不使用占位符,是字符串连接方式,使用Statement对象执行sql,效率低。
  4. $有sql注入的风险,缺乏安全性。
  5. $:可以替换表名或者列名。

mybatis的输出结果

mybatis执行了sql语句,得到java对象。

resultType结果类型

指sql语句执行完毕后, 数据转为的java对象, java类型是任意的。
resultType结果类型值 :

  1. 类型的全限定名称。
  2. 类型的别名, 例如 java.lang.Integer别名是int。

处理方式:

  1. mybatis执行sql语句, 然后mybatis调用类的无参数构造方法,创建对象。
  2. mybatis把ResultSet指定列值付给同名的属性。
1
2
3
<select id="selectMultiPosition" resultType="com.bjpowernode.domain.Student">
select id,name, email,age from student
</select>

对等的jdbc:

1
2
3
4
5
6
7
ResultSet rs = executeQuery(" select id,name, email,age from student" )
while(rs.next()){
Student student = new Student();
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"))
}

定义自定义类型的别名

  1. 在mybatis主配置文件中定义,使定义别名。
  2. 可以在resultType中使用自定义别名。
  3. resultMap:结果映射, 指定列名和java对象的属性对应关系。
    1)你自定义列值赋值给哪个属性。
    2)当你的列名和属性名不一样时,一定使用resultMap。
  4. resultMap和resultType不能同时用,二选一。

动态sql

  • sql的内容是变化的,可以根据条件获取到不同的sql语句。主要是where部分发生变化。
  • 动态sql的实现,使用的是mybatis提供的标签, ,,

是判断条件的。

语法

1
2
3
<if test="判断java对象的属性值">
部分sql语句
</if>

用来包含 多个的, 当多个if有一个成立的, 会自动增加一个where关键字,并去掉if中多余的and,or等。

循环java中的数组,list集合的。 主要用在sql的in语句中。
学生id是 1001,1002,1003的三个学生:

1
2
3
4
5
6
7
select * from student where id in (1001,1002,1003)
public List<Student> selectFor(List<Integer> idlist)
List<Integer> list = new ...
list.add(1001);
list.add(1002);
list.add(1003);
dao.selectFor(list)
1
2
3
<foreach collection="" item="" open="" close="" separator="">
#{xxx}
</foreach>
  • collection:表示接口中的方法参数的类型, 如果是数组使用array , 如果是list集合使用list
  • item:自定义的,表示数组和集合成员的变量
  • open:循环开始是的字符
  • close:循环结束时的字符
  • separator:集合成员之间的分隔符

sql代码片段

减少代码重复。

步骤

1.先定义

1
<sql id="自定义名称唯一">  sql语句, 表名,字段等 </sql>

2.再使用

1
<include refid="id的值" />

数据库的属性配置文件

把数据库连接信息放到一个单独的文件中。 和mybatis主配置文件分开。目的是便于修改,保存,处理多个数据库的信息。

  1. 在resources目录中定义一个属性配置文件, xxxx.properties ,例如 jdbc.properties
    在属性配置文件中, 定义数据,格式是 key=value
    key: 一般使用 . 做多级目录的。
    例如 jdbc.mysql.driver , jdbc.driver, mydriver

    1
    2
    3
    4
    jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql//.....
    jdbc.username=root
    jdbc.password=123456
  2. 在mybatis的主配置文件,使用 指定文件的位置
    在需要使用值的地方, ${key}

mapper文件,使用package指定路径

使用包名:

name: xml文件(mapper文件)所在的包名, 这个包中所有xml文件一次都能加载给mybatis

使用package的要求:

  1. mapper文件名称需要和接口名称一样, 区分大小写的一样。
  2. mapper文件和dao接口需要在同一目录。
1
2
3
<mappers>
<package name="com.bjpowernode.dao"/>
</mappers>

PageHelper

PageHelper做数据分页的。

MyBatis