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支持的构建包括有:
清理, 把之前项目编译的东西删除掉,为新的编译代码做准备。
编译, 把程序源代码编译为执行代码, java-class文件。批量的,maven可以同时把成千上百的文件编译为class。
测试, maven可以执行测试程序代码,验证你的功能是否正确。批量的,maven同时执行多个测试代码,同时测试很多功能。
报告, 生成测试结果的文件, 测试通过没有。
打包, 把你的项目中所有的class文件,配置文件等所有资源放到一个压缩文件中。这个压缩文件就是项目的结果文件, 通常java程序,压缩文件是jar扩展名的。对于web应用,压缩文件扩展名是.war
安装, 把5中生成的文件jar,war安装到本机仓库
部署, 把程序安装好可以执行。
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目录中。
设置本机存放资源的目录位置(设置本机仓库):
修改maven的配置文件, maven安装目录/conf/settings.xml
修改
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 | <groupId>公司域名的倒写</groupId> |
https://mvnrepository.com/ 搜索使用的中央仓库, 使用groupId 或者 artifactId作为搜索条件
2) packaging: 打包后压缩文件的扩展名,默认是jar ,web应用是war
packaging 可以不写, 默认是jar
依赖
dependencies 和dependency ,相当于是 java代码中import
你的项目中要使用的各种资源说明, 比如要使用mysql驱动
1 | <dependencies> |
properties:设置属性
build : maven在进行项目的构建时, 配置信息,例如指定编译java代码使用的jdk的版本等
maven生命周期, maven的命令,maven的插件
- maven的生命周期:就是maven构建项目的过程,清理,编译,测试,报告,打包,安装,部署。
- maven的命令:maven独立使用,通过命令,完成maven的生命周期的执行。maven可以使用命令,完成项目的清理,编译,测试等等。
- maven的插件: maven命令执行时,真正完成功能的是插件,插件就是一些jar文件, 一些类。
单元测试(测试方法)
用的是junit, junit是一个专门测试的框架(工具)。
- junit测试的内容: 测试的是类中的方法, 每一个方法都是独立测试的。方法是测试的基本单位(单元)。
- maven借助单元测试,批量的测试你类中的大量方法是否符合预期的。
使用步骤
- 加入依赖,在pom.xml加入单元测试依赖
1 | <!-- 单元测试 --> |
在maven项目中的src/test/java目录下,创建测试程序。
推荐的创建类和方法的提示:测试类的名称 是Test + 你要测试的类名
测试的方法名称 是:Test + 方法名称
例如你要测试HelloMaven ,
创建测试类 TestHelloMaven
1 |
|
其中testAdd叫做测试方法,它的定义规则
- 方法是public的,必须的
- 方法没有返回值, 必须的
- 方法名称是自定义的,推荐是Test + 方法名称
- 在方法的上面加入 @Test
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 | <!-junit的依赖范围是 test-> |
1 | <dependency> |
1 | <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 | <build> |
默认没有使用resources的时候, maven执行编译代码时, 会把src/main/resource目录中的文件拷贝到target/classes目录中。
MyBatis
三层架构
- 界面层: 和用户打交道的, 接收用户的请求参数, 显示处理结果的。(jsp ,html ,servlet)
- 业务逻辑层: 接收了界面层传递的数据,计算逻辑,调用数据库,获取数据
- 数据访问层: 就是访问数据库, 执行对数据的查询,修改,删除等等的。
三层对应的包
- 界面层: controller包 (servlet)
- 业务逻辑层: service 包(XXXService类)
- 数据访问层: dao包(XXXDao类)
三层中类的交互
用户使用界面层–> 业务逻辑层—>数据访问层(持久层)–>数据库(mysql)
三层对应的处理框架
- 界面层—servlet—springmvc(框架)
- 业务逻辑层—service类–spring(框架)
- 数据访问层—dao类–mybatis(框架)
框架
框架是一个模版:
- 规定了好一些条款,内容。
- 加入自己的东西。
框架是一个模块
- 框架中定义好了一些功能。这些功能是可用的。
- 可以加入项目中自己的功能, 这些功能可以利用框架中写好的功能。
框架是一个软件,半成品的软件,定义好了一些基础功能, 需要加入你的功能就是完整的。
基础功能是可重复使用的,可升级的。
框架特点:
- 框架一般不是全能的, 不能做所有事情。
- 框架是针对某一个领域有效。 特长在某一个方面,比如mybatis做数据库操作强,但是他不能做其它的。
- 框架是一个软件。
mybatis框架
一个框架,早期叫做ibatis, 代码在github。
mybatis是 MyBatis SQL Mapper Framework for Java (sql映射框架)
sql mapper :sql映射
可以把数据库表中的一行数据 映射为 一个java对象。
一行数据可以看做是一个java对象。操作这个对象,就相当于操作表中的数据Data Access Objects(DAOs) : 数据访问 , 对数据库执行增删改查。
mybatis提供了哪些功能:
提供了创建Connection ,Statement, ResultSet的能力 ,不用开发人员创建这些对象了。
提供了执行sql语句的能力, 不用你执行sql。
提供了循环sql, 把sql的结果转为java对象, List集合的能力。
1
2
3
4
5
6
7
8while (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);
}提供了关闭资源的能力,不用手动关闭Connection, Statement, ResultSet
流程: 开发人员提供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 | SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); |
SqlSessionFactory :
接口 , 接口实现类: DefaultSqlSessionFactory
重量级对象, 程序创建一个对象耗时比较长,使用资源比较多。
在整个项目中,有一个就够了。
作用:
获取SqlSession对象。SqlSession sqlSession = factory.openSession();
openSession()方法说明:
- openSession() :无参数的, 获取是非自动提交事务的SqlSession对象。
- openSession(boolean): openSession(true) 获取自动提交事务的SqlSession。
- 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 | <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注入),可以使用$。
# 和 $区别
- #使用 ?在sql语句中做站位的, 使用PreparedStatement执行sql,效率高。
- #能够避免sql注入,更安全。
- $不使用占位符,是字符串连接方式,使用Statement对象执行sql,效率低。
- $有sql注入的风险,缺乏安全性。
- $:可以替换表名或者列名。
mybatis的输出结果
mybatis执行了sql语句,得到java对象。
resultType结果类型
指sql语句执行完毕后, 数据转为的java对象, java类型是任意的。
resultType结果类型值 :
- 类型的全限定名称。
- 类型的别名, 例如 java.lang.Integer别名是int。
处理方式:
- mybatis执行sql语句, 然后mybatis调用类的无参数构造方法,创建对象。
- mybatis把ResultSet指定列值付给同名的属性。
1 | <select id="selectMultiPosition" resultType="com.bjpowernode.domain.Student"> |
对等的jdbc:
1 | ResultSet rs = executeQuery(" select id,name, email,age from student" ) |
定义自定义类型的别名
- 在mybatis主配置文件中定义,使
定义别名。 - 可以在resultType中使用自定义别名。
- resultMap:结果映射, 指定列名和java对象的属性对应关系。
1)你自定义列值赋值给哪个属性。
2)当你的列名和属性名不一样时,一定使用resultMap。 - resultMap和resultType不能同时用,二选一。
动态sql
- sql的内容是变化的,可以根据条件获取到不同的sql语句。主要是where部分发生变化。
- 动态sql的实现,使用的是mybatis提供的标签,
, ,
是判断条件的。
语法
1 | <if test="判断java对象的属性值"> |
用来包含 多个
循环java中的数组,list集合的。 主要用在sql的in语句中。
学生id是 1001,1002,1003的三个学生:
1 | select * from student where id in (1001,1002,1003) |
1 | <foreach collection="" item="" open="" close="" separator=""> |
- collection:表示接口中的方法参数的类型, 如果是数组使用array , 如果是list集合使用list
- item:自定义的,表示数组和集合成员的变量
- open:循环开始是的字符
- close:循环结束时的字符
- separator:集合成员之间的分隔符
sql代码片段
减少代码重复。
步骤
1.先定义
1 | <sql id="自定义名称唯一"> sql语句, 表名,字段等 </sql> |
2.再使用
1 | <include refid="id的值" /> |
数据库的属性配置文件
把数据库连接信息放到一个单独的文件中。 和mybatis主配置文件分开。目的是便于修改,保存,处理多个数据库的信息。
在resources目录中定义一个属性配置文件, xxxx.properties ,例如 jdbc.properties
在属性配置文件中, 定义数据,格式是 key=value
key: 一般使用 . 做多级目录的。
例如 jdbc.mysql.driver , jdbc.driver, mydriver1
2
3
4jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql//.....
jdbc.username=root
jdbc.password=123456在mybatis的主配置文件,使用
指定文件的位置
在需要使用值的地方, ${key}
mapper文件,使用package指定路径
使用包名:
name: xml文件(mapper文件)所在的包名, 这个包中所有xml文件一次都能加载给mybatis
使用package的要求:
- mapper文件名称需要和接口名称一样, 区分大小写的一样。
- mapper文件和dao接口需要在同一目录。
1 | <mappers> |
PageHelper
PageHelper做数据分页的。