闲话
最近开始学习《计算机网络:自顶向下方法》,买的是一本实体书,就不方便上传博客了,所以打算抽空把工作中常用的框架复习一遍,巩固巩固
一、什么是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注入)。 这样做更安全,更迅速,通常也是首选做法,而${}创建的是Statement 参数占位符
不过有时你就是想直接在 SQL 语句中直接插入一个不转义的字符串。
比如 ORDER BY 子句,这时候你可以:
ORDER BY ${columnName}
这样,MyBatis 就不会修改或转义该字符串了
二、一个简单的项目搭建
1、依赖导入
我们创建一个maven项目,所以需要配置pom.xml文件
<dependencies>
<!--Mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!--MySQL驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.27</version>
</dependency>
<!--Junit-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.1</version>
<scope>test</scope>
</dependency>
</dependencies>
2、核心配置
配置核心配置文件mybatis-config.xml,连接本地的数据库
注意:数据库连接url里,参数连接符需要用 &;
另外,记得设置项目的编码为utf-8,否则运行后面的测试类会因为这里注释中有中文报错,路径为setting-File Encodings
<?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">
<!--驱动配置,com.mysql.jdbc.driver -->
<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>
<!--每一个mapper.xml文件都需要在核心配置文件中注册-->
<mappers>
<mapper resource="com/decade/mapper/UserMapper.xml"/>
</mappers>
</configuration>
但是,由于maven约定大于配置的原因,我们写的配置文件如果放在Java文件夹下,那么就可能会出现无法被导出或生效的问题,所以,我们需要在pom文件里进行如下配置
<!--在build中配置resources,来防止我们资源导出失败的问题-->
<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>
3、代码编写
- 首先编写一个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;
/**
* Mybatis工具类
*/
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory;
static {
try {
// 使用Mybatis第一步:获取sqlSession
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
// 既然有了sqlSessionFactory,我们就可以得到sqlSession实例了
// sqlSession完全包含了面向数据库执行sql命令所需要的方法,如果要开启自动提交事务,openSession中设置true即可
public static SqlSession getSqlSession() {
return sqlSessionFactory.openSession();
}
}
- 编写实体类
package com.decade.entity;
/**
* 人员信息
*/
public class User {
private String id;
private String name;
private int age;
private String sex;
public User(String userId, String name, int age, String sex) {
this.id = userId;
this.name = name;
this.age = age;
this.sex = sex;
}
public String getName() {
return name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
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{"
+ "id='" + id + '\''
+ ", name='" + name + '\''
+ ", age=" + age
+ ", sex='" + sex + '\''
+ '}';
}
}
- Dao接口
import com.decade.entity.User;
import java.util.List;
public interface UserDao {
List<User> getUserInfo();
}
- 接口实现类(由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>
- 编写一个测试类进行测试
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 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");
// 循环输出查询到的user信息
userList.forEach(System.out::println);
} catch (Exception e) {
e.printStackTrace();
} finally {
// 关闭sqlSession
sqlSession.close();
}
}
}
运行测试类结果如下
如有错误,欢迎指正
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/136791.html