MyBatis 中使用 Mapper 簡(jiǎn)化代碼的方法
前面文章所寫(xiě)的增刪改查是存在問(wèn)題的。每執(zhí)行一次 SQL,都要開(kāi)啟一次會(huì)話,并且需要提交并關(guān)閉,主要問(wèn)題就是冗余代碼過(guò)多,模板化代碼過(guò)多。
例如,我想開(kāi)發(fā)一個(gè) UserDao,可能是下面這樣:
簡(jiǎn)化前的 UserDao
public class UserDao {
private SqlSessionFactory sqlSessionFactory = SqlSessionFactoryUtils.getInstance();
public User getUserById(Integer id) {
SqlSession sqlSession = sqlSessionFactory.openSession();
User user = (User) sqlSession.selectOne("com.antonio.hello.mybatis.mapper.UserDao.getUserById", id);
sqlSession.close();
return user;
}
public Integer addUser(User user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
int insert = sqlSession.insert("com.antonio.hello.mybatis.mapper.UserDao.addUser", user);
sqlSession.commit();
sqlSession.close();
return insert;
}
public Integer addUser2(User user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
int insert = sqlSession.insert("com.antonio.hello.mybatis.mapper.UserDao.addUser2", user);
sqlSession.commit();
sqlSession.close();
return insert;
}
public Integer deleteUserById(Integer id) {
SqlSession sqlSession = sqlSessionFactory.openSession();
int delete = sqlSession.delete("com.antonio.hello.mybatis.mapper.UserDao.deleteUserById", id);
sqlSession.commit();
sqlSession.close();
return delete;
}
public Integer updateUser(User user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
int delete = sqlSession.delete("com.antonio.hello.mybatis.mapper.UserDao.updateUser", user);
sqlSession.commit();
sqlSession.close();
return delete;
}
public List<User> getAllUser() {
SqlSession sqlSession = sqlSessionFactory.openSession();
List<User> users = sqlSession.selectList("com.antonio.hello.mybatis.mapper.UserDao.getAllUser");
sqlSession.close();
return users;
}
}
對(duì)應(yīng)的 UserMapper.xml
然后,和這個(gè) UserDao 對(duì)應(yīng)的,還有一個(gè) 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">
<mapper namespace="com.antonio.hello.mybatis.mapper.UserDao">
<select id="getUserById" resultType="com.antonio.hello.mybatis.entity.User">
select * from user where id=#{id};
</select>
<insert id="addUser" parameterType="com.antonio.hello.mybatis.entity.User">
insert into user (username,address) values (#{username},#{address});
</insert>
<insert id="addUser2" parameterType="com.antonio.hello.mybatis.entity.User">
<selectKey resultType="java.lang.String" keyProperty="id" order="BEFORE">
select uuid();
</selectKey>
insert into user (id,username,address) values (#{id},#{username},#{address});
</insert>
<delete id="deleteUserById" parameterType="java.lang.Integer">
delete from user where id=#{id}
</delete>
<update id="updateUser" parameterType="com.antonio.hello.mybatis.entity.User">
update user set username = #{username} where id=#{id};
</update>
<select id="getAllUser" resultType="com.antonio.hello.mybatis.entity.User">
select * from user;
</select>
</mapper>
此時(shí),我們分析這個(gè) UserDao,發(fā)現(xiàn)它有很多可以優(yōu)化的地方。每個(gè)方法中都要獲取 SqlSession,涉及到增刪改的方法,還需要 commit,SqlSession 用完之后,還需要關(guān)閉,sqlSession 執(zhí)行時(shí)需要的參數(shù)就是方法的參數(shù),sqlSession 要執(zhí)行的 SQL ,和 XML 中的定義是一一對(duì)應(yīng)的。這是一個(gè)模板化程度很高的代碼。
簡(jiǎn)化后的 UserDao
既然模板化程度很高,我們就要去解決它,原理很簡(jiǎn)單,就是前面 Spring 中所說(shuō)的動(dòng)態(tài)代理。我們可以將 UserDao 簡(jiǎn)化成一個(gè)接口:
package com.antonio.hello.mybatis.mapper;
public interface UserDao {
User getUserById(Integer id);
Integer addUser(User user);
Integer addUser2(User user);
Integer deleteUserById(Integer id);
Integer updateUser(User user);
List<User> getAllUser();
}
使用這個(gè)接口,完全可以代替上面的 UserDao,為什么呢?因?yàn)檫@個(gè)接口提供了 UserDao 所需要的最核心的東西,根據(jù)這個(gè)接口,就可以自動(dòng)生成 UserDao:
- 首先,UserDao 中定義了 SqlSessionFactory,這是一套固定的代碼
- UserMapper 所在的包 + UserMapper 類名 + UserMapper 中定義好的方法名,就可以定位到要調(diào)用的 SQL
- 要調(diào)用 SqlSession 中的哪個(gè)方法,根據(jù)定位到的 SQL 節(jié)點(diǎn)就能確定
配置并使用
因此,我們?cè)?MyBatis 開(kāi)發(fā)中,實(shí)際上不需要自己提供 UserDao 的實(shí)現(xiàn),我們只需要提供一個(gè) UserMapper 即可。然后,我們?cè)?MyBatis 的全局配置中,配置一下 UserMapper:
<?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.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///test01?serverTimezone=Asia/Shanghai"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<mappers>
<package name="com.antonio.hello.mybatis.mapper"/>
</mappers>
</configuration>
然后,加載配置文件,獲取 UserMapper,并調(diào)用它里邊的方法:
public class Main2 {
public static void main(String[] args) {
SqlSessionFactory instance = SqlSessionFactoryUtils.getInstance();
SqlSession sqlSession = instance.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
List<User> allUser = mapper.getAllUser();
System.out.println(allUser);
}
}
注意,在 Maven 中,默認(rèn)情況下,Maven 要求我們將 XML 配置、properties 配置等,都放在 resources 目錄下,如果我們強(qiáng)行放在 java 目錄下,默認(rèn)情況下,打包的時(shí)候這個(gè)配置文件會(huì)被自動(dòng)忽略掉。對(duì)于這兩個(gè)問(wèn)題,我們有兩種解決辦法:
不忽略 XML 配置:
我們可以在 pom.xml 中,添加如下配置,讓 Maven 不要忽略我在 java 目錄下的 XML 配置:
<build>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
<resource>
<directory>src/main/resources</directory>
</resource>
</resources>
</build>
按照 Maven 的要求來(lái)
按照 Maven 的要求來(lái),將 xml 文件放到 resources 目錄下,但是,MyBatis 中默認(rèn)情況下要求,UserMapper.xml 和 UserMapper 接口,必須放在一起,所以,我們需要手動(dòng)在 resources 目錄下,創(chuàng)建一個(gè)和 UserMapper 接口相同的目錄存放 UserMapper.xml。這樣,我們就不需要在 pom.xml 文件中添加配置了,因?yàn)檫@種寫(xiě)法同時(shí)滿足了 Maven 和 MyBatis 的要求。
到此這篇關(guān)于MyBatis 中使用 Mapper 簡(jiǎn)化代碼的方法的文章就介紹到這了,更多相關(guān)MyBatis 使用 Mapper 簡(jiǎn)化代碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java static塊和構(gòu)造函數(shù)的實(shí)例詳解
這篇文章主要介紹了java static塊和構(gòu)造函數(shù)的實(shí)例詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握J(rèn)ava static關(guān)鍵字的函數(shù)方法,需要的朋友可以參考下2017-09-09
SpringBoot接口加密與解密的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot接口加密與解密的實(shí)現(xiàn)2023-10-10
SpringBoot MongoDB與MongoDB GridFS基本使用
這篇文章主要為大家介紹了SpringBoot MongoDB與MongoDB GridFS基本使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
Java FTPClient連接池的實(shí)現(xiàn)
這篇文章主要介紹了Java FTPClient連接池的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
MyBatis-Plus中使用EntityWrappe進(jìn)行列表數(shù)據(jù)倒序設(shè)置方式
這篇文章主要介紹了MyBatis-Plus中使用EntityWrappe進(jìn)行列表數(shù)據(jù)倒序設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Java實(shí)現(xiàn)短信驗(yàn)證碼詳細(xì)過(guò)程
這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)短信驗(yàn)證碼的相關(guān)資料, 在業(yè)務(wù)需求中我們經(jīng)常會(huì)用到短信驗(yàn)證碼,比如手機(jī)號(hào)登錄、綁定手機(jī)號(hào)、忘記密碼、敏感操作等,需要的朋友可以參考下2023-09-09
Java實(shí)現(xiàn)將PDF轉(zhuǎn)為圖片格式的方法詳解
PDF文件和圖片文件,這是兩種完全不一樣的格式,可是有的時(shí)候這兩種格式卻是有相互轉(zhuǎn)換的需要,本文將介紹如何通過(guò)Java應(yīng)用程序快速高效地將PDF轉(zhuǎn)為圖片格式。一起來(lái)看看吧2023-03-03

