MyBatis初识
(只需要掌握好掌握好sql,是一种半自动化的持久化层框架,),
1,初始MyBatis,
创建一些数据库和表,创建test库、emp表,并插入若干条记录。
1 -- 1、创建数据库 test 数据库 2 create database if not exists test charset utf8; 3 use test ; -- 选择yonghedb数据库 4 -- 2、删除emp表(如果存在) 5 drop table if exists emp; 6 -- 3、在 test 库中创建 emp 表 7 create table emp( 8 id int primary key auto_increment, 9 name varchar(50), 10 job varchar(50),
11
salary double
12
);
13
-- 4、往 emp 表中, 插入若干条记录
14
insert into emp values(null, '张三', '程序员', 3300);
15
insert into emp values(null, '李四', '程序员', 2800);
16
insert into emp values(null, '王五', '程序员鼓励师', 2700);
17
insert into emp values(null, '王二', '部门总监', 4200);
18
insert into emp values(null, '麻子', '程序员', 3000);
19
insert into emp values(null, '最帅三太子', '程序员', 3500);
20
insert into emp values(null, '苍老师', '程序员', 3700); 21 insert into emp values(null, '波多野结衣', 'CEO', 5000);
2,创建项目,(ider这里我用的是),创建项目名称,

2、导入junit、mysql驱动器、mybaits、log4j这四个包。(先创建好项目)
在pom.xml文件中引入相关依赖包(不引入会报错)
下面这里是添加一些东西在xml文件下。
1
<dependencies>
2
<!-- junit单元测试 -->
3
<dependency>
4
<groupId>junit</groupId>
5
<artifactId>junit</artifactId>
6
<version>4.9</version>
7
</dependency>
8
<!-- mysql驱动 -->
9
<dependency>
10
<groupId>mysql</groupId>
11
<artifactId>mysql-connector-java</artifactId> 12 <version>5.1.32</version> 13 </dependency> 14 <!-- mybatis --> 15 <dependency> 16 <groupId>org.mybatis</groupId> 17 <artifactId>mybatis</artifactId>
18
<version>3.2.8</version>
19
</dependency>
20
<!-- 整合log4j -->
21
<dependency>
22
<groupId>org.slf4j</groupId>
23
<artifactId>slf4j-log4j12</artifactId>
24
<version>1.6.4</version>
25
</dependency>
26
</dependencies>
3、创建com.tedu.mybatis.TestMybatis01测试类,并提供findAll方法(查询emp表中所有的员工信息),开发步骤如下:(创建测试类)
![]()
1
/** 练习1(快速入门): 查询emp表中的所有员工, 返回一个List<Emp>集合
2
* @throws IOException */
3
@Test
4
public void findAll() throws IOException {
5
//1.读取mybatis的核心配置文件(mybatis-config.xml)
6
//2.通过配置信息获取一个SqlSessionFactory工厂对象
7
//3.通过工厂获取一个SqlSession对象
8
//4.通过namespace+id找到要执行的sql语句并执行sql语句
9
//5.输出结果
10
}
添加mybatis-config.xml文件
1、在src/main/resources目录下,创建mybatis-config.xml文件(MyBatis的核心配置文件)
![]()
2、mybatis-config.xml文件配置如下:
mybatis-config文件头信息如下:
1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE configuration
3
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
4
"http://mybatis.org/dtd/mybatis-3-config.dtd">
5
6
<!-- MyBatis的全局配置文件 -->
7
<configuration >
8
9
</configuration>
mybatis-config文件详细配置如下:
1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE configuration
3
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
4
"http://mybatis.org/dtd/mybatis-3-config.dtd">
5
6
<!-- MyBatis的全局配置文件 -->
7
<configuration >
8
<!-- 1.配置环境,可配置多个环境(比如:develop开发、test测试) -->
9
<environments default="develop">
10
<environment id="develop">
11
12
<!-- 1.1.配置事务管理方式:JDBC/MANAGED
13
JDBC:将事务交给JDBC管理(推荐)
14
MANAGED:自己管理事务
15
-->
16
<transactionManager type="JDBC"></transactionManager>
17
18
<!-- 1.2.配置数据源,即连接池 JNDI/POOLED/UNPOOLED
19
JNDI:已过时
20
POOLED:使用连接池(推荐)
21
UNPOOLED:不使用连接池
22
-->
23
<dataSource type="POOLED">
24
<property name="driver" value="com.mysql.jdbc.Driver"/>
25
<property name="url" value="jdbc:mysql://localhost:3306/yonghedb?characterEncoding=utf-8"/>
26
<property name="username" value="root"/>
27
<property name="password" value="root"/>
28
</dataSource>
29
</environment>
30
</environments>
31
<!-- 2.导入Mapper配置文件,如果mapper文件有多个,可以通过多个mapper标签导入 -->
33
<mappers>
34
<mapper resource="EmpMapper.xml"/>
35
</mappers>
36
</configuration>
3,添加EmpMapper.xml文件
1、在src/main/resources目录下,创建EmpMapper.xml文件 (实体类的映射文件)
2、EmpMapper.xml文件配置如下:
EmpMapper文件头信息如下:
1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE mapper
3
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
4
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
5
6
<!--
7
不同Mapper文件的namespace值应该保证唯一
8
在程序中通过[ namespace + id ]定位到要执行哪一条SQL语句
9
-->
10
<mapper namespace="">
11
12
13
</mapper>
EmpMapper文件详细配置如下:
1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE mapper
3
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
4
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
5
6
<!--
7
不同Mapper文件的namespace值应该保证唯一
8
在程序中通过[ namespace + id ]定位到要执行哪一条SQL语句
9
-->
10
<mapper namespace="EmpMapper">
11
<!-- 通过select、insert、update、delete标签声明要执行的SQL -->
12
<!-- 练习1: 查询emp表中的所有员工信息
13
resultType指定查询的结果将会封装到什么类型中
14
即使最终返回的结果是集合(List<Emp>),resultType也只需要指定集合中的泛型即可!
15
-->
16
<select id="findAll" resultType="com.tedu.pojo.Emp">
17
select * from emp
18
</select>
19
20
</mapper>
4,接下来是MVC三层架构勒。
添加并编写Emp实体类
注意:在当前实例中,Emp类中的属性和数据库表的字段名称必须一致,否则将会无法将结果集封装到Java对象中。(基础)
在src/main/java目录下创建 com.tedu.pojo.Emp类,并编辑Emp类:提供私有属性以及对应的getter方法、setter方法,并重写toString方法(注意顺序)
1
package com.tedu.pojo;
2
/**
3
* 实体类,用于封装Emp表中的一条用户信息
4
*/
5
public class Emp {
6
//1.声明实体类中的属性
7
private Integer id;
8
private String name;
9
private String job;
10
private Double salary;
11
12
//2.提供对应的getter和setter方法
13
public Integer getId() {
14
return id;
15
}
16
public void setId(Integer id) {
17
this.id = id;
18
}
19
public String getName() {
20
return name;
21
}
22
public void setName(String name) {
23
this.name = name;
24
}
25
public String getJob() {
26
return job;
27
}
28
public void setJob(String job) {
29
this.job = job;
30
}
31
public Double getSalary() {
32
return salary;
33
}
34
public void setSalary(Double salary) {
35
this.salary = salary;
36
}
37
38
//3.重写toString方法
39
@Override
40
public String toString() {
41
return "Emp [id=" + id + ", name=" + name + ", job=" + job + ", salary=" + salary + "]";
42
}
43
}
实现测试类,并测试
1、实现findAll方法,代码如下:
1
/** 练习1(快速入门): 查询emp表中的所有员工, 返回一个List<Emp>集合
2
* @throws IOException */
3
@Test
4
public void findAll() throws IOException {
5
//1.读取mybatis的核心配置文件(mybatis-config.xml)
6
InputStream in = Resources
7
.getResourceAsStream("mybatis-config.xml");
8
//2.通过配置信息获取一个SqlSessionFactory工厂对象
9
SqlSessionFactory fac =
10
new SqlSessionFactoryBuilder().build( in );
11
//3.通过工厂获取一个SqlSession对象
12
SqlSession session = fac.openSession();
13
//4.通过namespace+id找到要执行的sql语句并执行sql语句
14
List<Emp> list = session
15
.selectList("EmpMapper.findAll");
16
//5.输出结果
17
for(Emp e : list) {
18
System.out.println( e );
19
}
20
}
2、执行findAll方法,输出结果为:
就会遍历出来
(这里也没有一步一步的教的来做,有需要一步一步详细步骤的,可以找我)



浙公网安备 33010602011771号