一、mybatis概述
一个实现数据持久化的开源框架。是对JDBC的封装。
二、mybatis核心接口和类
1)SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession
2)获取原理SqlSessionFactory
三、使用方式
1)新建数据库表
-- ----------------------------
-- Table structure for author
-- ----------------------------
DROP TABLE IF EXISTS `author`;
CREATE TABLE `author` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`sex` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of author
-- ----------------------------
INSERT INTO `author` VALUES ('1', 'aki', '1', '男');
INSERT INTO `author` VALUES ('2', '澳门', '2', '女');
2)新建数据库实体类
import lombok.Data;
@Data
public class User {
private int id;
private int age;
private String name;
private String sex;
}
3)创建mybatis的配置文件config.xml(文件名随意,创建在resources下面)
- 配置JDBC事务
- 配置JDBC数据源连接池
- 配置的基本操作(注册驱动。。。)
<?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">
<configuration>
<typeAliases>
<package name="com.example.demo.mapper"></package>
</typeAliases>
<environments default="development">
<environment id="development">
<!--使用jdbc事务管理 -->
<transactionManager type="JDBC"/>
<!-- 数据库连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/my_test?serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<!-- 引入映射配置文件 -->
<mappers>
<mapper resource="com/example/demo/mapper/UserMapper.xml"/>
</mappers>
</configuration>
4)使用原生接口(新建包)
(1)需要开发者自定义SQL语句,写在Mapper.xml文件中,在实际开发中,会为每个实体类创建对应的Mapper.xml,定义管理该对象数据的SQL
*namespace通常设置为文件所在包加文件名的形式
*id属性是指实际调用Mybatis方法需要用到的参数
*parameterType是调用对应方法时的数据类型
(2)在全局配置文件config.xml中注册mapper
*resource中的路径要用/作为分割
<?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">
<!-- namespace:命名空间,用于隔离sql-->
<mapper namespace="com.example.demo.mapper.UserMapper">
<select id="findAll" resultType="com.example.demo.mapper.User">
select * from author
</select>
</mapper>
(3)使用
InputStream i = HelloCpntroller.class.getClassLoader().getResourceAsStream("config.xml");
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory =sqlSessionFactoryBuilder.build(i);
SqlSession sqlSession = sqlSessionFactory.openSession();
String statment = "com.example.demo.mapper.UserMapper.findAll";
List<User> users = sqlSession.selectList(statment);
sqlSession.commit();
5)注意事项:
*在使用时要配置这个属性,否则会找不到mapper.xml
processResources {
from('src/main/java') {
include '**/*.xml'
}
}
*建立实体类的时候导入的依赖
compileOnly 'org.projectlombok:lombok:1.18.6'
annotationProcessor 'org.projectlombok:lombok:1.18.6'