目录
一、创建一个默认的maven项目
二、添加依赖
本次mybatisDemo会用到mysql、mybatis、junit三个jar包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!--父工程-->
<groupId>com.kuang</groupId>
<artifactId>mybatisDemo</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>mybatis-01</module>
</modules>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.18</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
</dependency>
</dependencies>
</project>
三、创建实体类
User.java:
package com.kuang.pojo;
/**
* @author flj
* @Desc
* @create 2021-07-26-17:30
*/
public class User {
private int id;
private String name;
private String pwd;
public User(int id, String name, String pwd) {
this.id = id;
this.name = name;
this.pwd = pwd;
}
public User() {
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPwd() {
return pwd;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
", pwd='" + pwd + '\'' +
'}';
}
}
四、创建UserDAO/UserMapper接口
UserDAO.java(应该命名为UserMapper,为了方便理解我用的是UserDAO):
package com.kuang.dao;
import com.kuang.pojo.User;
import java.util.List;
/**
* @author flj
* @Desc
* @create 2021-07-26-18:35
*/
//应该命名为UserMapper
public interface UserDAO {
List<User> selectAll();
}
五、编写mybatisUtil类获取sqlSession
MybatisUtil.java:
package com.kuang.utils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.IOException;
import java.io.InputStream;
/**
* @author flj
* @Desc
* @create 2021-07-26-16:37
*/
public class MybatisUtil {
private static SqlSessionFactory sqlSessionFactory;
static {
try {
//获取sqlSessionFactory对象
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
//有了SqlsessionFactory就可以获取SqlSession实例了
//Sqlsession完全包含了面向数据库执行SQl命令所需要的所有方法
public static SqlSession getSqlSession(){
SqlSession sqlSession = sqlSessionFactory.openSession();
return sqlSession;
}
}
六、编写jdbc配置文件
jdbc.properties:
jdbc.url=jdbc:mysql://127.0.0.1:3306/mybatis?useUnicode=true&useSSL=false&characterEncoding=utf-8&serverTimezone=UTC
jdbc.username=root
jdbc.password=125816
jdbc.driver-class-name=com.mysql.cj.jdbc.Driver
七、创建UserMapper.xml
在资源目录下创建mappers文件夹,在此文件夹下创建UserMapper.xml文件,并在其中绑定mapper接口编写SQL语句。这就相当于UserDAO接口的实现类UserDAoImpl。
UserMapper.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">
<!--UserMapper.xml就相当于UserDAO的实现类UserDAOImpl-->
<!--namespace绑定了一个对应的DAO/mapper接口-->
<mapper namespace="com.kuang.dao.UserDAO">
<select id="selectAll" resultType="com.kuang.pojo.User">
select * from user
</select>
</mapper>
八、编写mybatis核心配置文件
在mybatis核心配置文件中注册UserMapper接口
mybatis-config.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">
<configuration>
<!-- 让MyBatis自动读取我们的数据库配置文件 -->
<properties resource="jdbc.properties" />
<!--配置数据库连接操作环境-->
<environments default="product">
<!-- 例:开发时的数据库配置 -->
<environment id="dev">
<!-- 自动使用jdbc中的事务处理 -->
<transactionManager type="JDBC"></transactionManager>
<!-- 开启连接池的支持 -->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver-class-name}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
<!-- 例:用于生产的数据库配置 -->
<environment id="product">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver-class-name}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!-- 配置mapper之前,建议大家首先创建 CustomerMapper.xml 文件 -->
<!--关联映Mapper接口的射文件,每一个mapper.xml都必须在mybatis的核心配置文件中注册-->
<mappers>
<mapper resource="mappers/UserMapper.xml"/>
</mappers>
</configuration>
九、创建测试类
UserDAOTest.java:
package com.kuang.dao;
import com.kuang.pojo.User;
import com.kuang.utils.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.util.List;
/**
* @author flj
* @Desc
* @create 2021-07-26-19:48
*/
public class UserDAOTest {
@Test
public void test(){
SqlSession sqlSession = MybatisUtil.getSqlSession();
//方式一:
UserDAO userDAO = sqlSession.getMapper(UserDAO.class);
List<User> users = userDAO.selectAll();
for(User user:users){
System.out.println(user);
}
//关闭sqlsession
sqlSession.close();
}
}
十、测试结果
十一、该Demo的目录结构