Mybatis
MyBatis
- MyBatis是一个Java持久层框架,它封装了jdbc,使开发者只关注sql语句本身
- MyBatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中的sql的动态参数进行映射生成最终执行的SQL语句
- 采用ORM思想解决了实体和数据库映射的问题,对JDBC进行封装,屏蔽了JDBC API底层的访问细节
ORM
- Object Relational Mapping:对象关系映射
- 将数据库表和实体类及实体类的属性对应起来
环境搭建
总目录关系
1.创建maven工程并jar包
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.4</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.45</version>
</dependency>
测试使用:
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.2</version>
<scope>test</scope>
</dependency>
2.创建实体类User
package com.sun.domain;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import java.io.Serializable;
import java.sql.Timestamp;
@Getter
@Setter
@ToString
public class User implements Serializable {
private int userId;
private String name;
private String password;
private String nickName;
private Timestamp lastLogout;
}
3.创建MyBatis主配置文件(SqlMapConfig.xml)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- mybatis的主配置文件-->
<configuration>
<!--环境配置-->
<environments default="mysql">
<!--配置mysql环境-->
<environment id="mysql">
<!--配置事务类型-->
<transactionManager type="JDBC"></transactionManager>
<!--配置数据源(连接池)-->
<dataSource type="POOLED">
<!--配置连接数据库的基本信息-->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/chatroom"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!-- 指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件-->
<mappers>
<mapper resource="com/sun/dao/Userdao.xml"/>
</mappers>
</configuration>
4.创建持久层接口IUserDAO
package com.sun.dao;
import com.sun.domain.User;
import java.util.List;
/*
用户的持久层接口
*/
public interface IUserDAO {
List<User> findAll();
}
5.创建映射配置文件(UserDao.xml)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--映射配置文件-->
<mapper namespace="com.sun.dao.IUserDAO">
<!--配置查询所有-->
<select id="findAll" resultType="com.sun.domain.User">
select * from user
</select>
</mapper>
6.测试
@Test
public void testFindAll()throws Exception{
//1.读取配置文件,生产字节输入流
InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
//3.使用工厂生产SqlSession对象
SqlSession session = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
IUserDAO userDao = session.getMapper(IUserDAO.class);
//5.使用代理对象执行方法
List<User> all = userDao.findAll();
for (User user : all) {
System.out.println(user);
}
//6.关闭资源
session.close();
in.close();
}
结果:
注意事项:
- 创建IUserDao. xml和IUserDao. java时名称是为了和我们之前的知识保持一致。在Mybatis中它把持久层的操作接口名称和映射文件也叫做: Mapper,所以:IUserDao和IUserMapper是一样的
- 在idea中创建目录的时候,它和包是不一样的,包在创建时:com. itheima. dao它是三级结构目录在创建时: com. itheima. dao是一级目录
- mybatis的映射配置文件位置必须和dao接口的包结构相同
- 映射配置文件的mapper标签namespace属性的取值必须是dao接口的全限定类名
- 映射配置文件的操作配置(select), id属性的取值必须是dao接口的方法名
当我们遵从了第三,四,五点之后,我们在开发中就无须再写dao的实现类。
注解开发环境搭建
目录结构
1.创建实体类和dao接口
实体类
package sun.domain;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import java.io.Serializable;
import java.sql.Timestamp;
@Getter
@Setter
@ToString
public class User implements Serializable {
private int userId;
private String name;
private String password;
private String nickName;
private Timestamp lastLogout;
}
dao接口
package sun.dao;
import org.apache.ibatis.annotations.Select;
import sun.domain.User;
import java.util.List;
//在mybatis中针对CRUD一共有四个注解
public interface IUserdao {
@Select("select * from user")
List<User> findAll();
}
2.配置SqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- mybatis的主配置文件-->
<configuration>
<!--配置别名-->
<typeAliases>
<package name="sun.domain"/>
</typeAliases>
<!--环境配置-->
<environments default="mysql">
<!--配置mysql环境-->
<environment id="mysql">
<!--配置事务类型-->
<transactionManager type="JDBC"></transactionManager>
<!--配置数据源(连接池)-->
<dataSource type="POOLED">
<!--配置连接数据库的基本信息-->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/chatroom"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!-- 指定带有注解的dao接口所在位置-->
<mappers>
<package name="sun.dao"/>
</mappers>
</configuration>
3.测试
public static void main(String[] args) throws IOException {
//1.读取配置文件
InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
//3.使用工厂生产SqlSession对象
SqlSession session = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
IUserdao userDao = session.getMapper(IUserdao.class);
//5.使用代理对象执行方法
List<User> all = userDao.findAll();
for (User user : all) {
System.out.println(user);
}
//6.关闭资源
session.close();
in.close();
}
结果:
注意:
- 使用注解开发就不能使用xml开发