闲话
最近开始学习《计算机网络:自顶向下方法》,买的是一本实体书,就不方便上传博客了,所以打算抽空把工作中常用的框架复习一遍,巩固巩固
一、什么是Mybatis
1、官方文档:Mybatis官网
2、简介
- MyBatis 是一款优秀的持久层框架(dao层,主要与数据库进行交互),它支持自定义 SQL、存储过程以及高级映射
- MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作
- MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java - Objects,普通老式 Java 对象)为数据库中的记录
数据持久化:就是将程序的数据在持久状态(数据库)和瞬时状态(内存)转化的过程
3、为什么使用mybatis:JDBC代码复杂,使用mybatis简化操作,自动化
4、优点:
- 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用
- 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
- 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
- 提供映射标签,支持对象与数据库的orm字段关系映射
- 提供对象关系映射标签,支持对象关系组建维护
- 提供xml标签,支持编写动态sql
5、关于#和$ #{}是预编译处理,${}是字符串替换
默认情况下,我们都会使用 #{}参数语法时,MyBatis 会创建PreparedStatement 参数占位符,并通过占位符安全地设置参数(就像使用 ? 一样,防止SQL注入)。 这样做更安全,更迅速,通常也是首选做法
不过有时你就是想直接在 SQL 语句中直接插入一个不转义的字符串。 比如 ORDER BY 子句,这时候你可以:
ORDER BY ${columnName}
这样,MyBatis 就不会修改或转义该字符串了
二、一个简单的项目搭建
1、依赖导入 我们创建一个maven项目,所以需要配置pom.xml文件
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.27</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.1</version>
<scope>test</scope>
</dependency>
</dependencies>
2、代码编写
- 首先编写一个Mybatis工具类,获取sqlSession,sqlSession完全包含了面向数据库执行sql命令所需要的方法
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;
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory;
static {
try {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
public static SqlSession getSqlSession() {
return sqlSessionFactory.openSession();
}
}
public class User {
private String userId;
private String name;
private int age;
private String sex;
public User(String userId, String name, int age, String sex) {
this.userId = userId;
this.name = name;
this.age = age;
this.sex = sex;
}
public String getName() {
return name;
}
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
@Override
public String toString() {
return "User{"
+ "userId='" + userId + '\''
+ ", name='" + name + '\''
+ ", age=" + age
+ ", sex='" + sex + '\''
+ '}';
}
}
import com.decade.entity.User;
import java.util.List;
public interface UserDao {
List<User> getUserInfo(String userName);
}
- 接口实现类(由jdbc实现类变成了Mapper.xml配置文件)
namespace绑定Mapper接口
<?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.decade.mapper.UserDao">
<select id="getUserInfo" resultType="com.decade.entity.User">
select * from t_decade_user;
</select>
</mapper>
- 然后我们需要配置核心配置文件mybatis-config.xml,连接本地的数据库
注意:数据库连接url里,参数连接符需要用 &;
<?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>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/decade/mapper/UserMapper.xml"/>
</mappers>
</configuration>
但是,由于maven约定大于配置的原因,我们写的配置文件如果放在Java文件夹下,那么就可能会出现无法被导出或生效的问题,所以,我们需要在pom文件里进行如下配置
<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
import com.decade.entity.User;
import com.decade.mapper.UserDao;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import com.decade.utils.MybatisUtils;
import java.util.List;
public class UserDaoTest {
@Test
public void test() {
SqlSession sqlSession = MybatisUtils.getSqlSession();
try {
UserDao userDao = sqlSession.getMapper(UserDao.class);
List<User> userList = userDao.getUserInfo();
List<User> userInfos = sqlSession.selectList("com.decade.mapper.UserDao.getUserInfo");
userList.forEach(System.out::println);
} catch (Exception e) {
e.printStackTrace();
} finally {
sqlSession.close();
}
}
}
运行测试类结果如下
如有错误,欢迎指正
|