【Java】Mybatis mapper動態代理方式

我們在使用Mybatis的時候,獲取需要執行的SQL語句的時候,都是通過呼叫xml檔案來獲取,例如: User user = (User) sqlSession.selectOne("cn.ddnd.www.Entity.User.getUser", "[email protected]");
。這種方式是通過字串去呼叫標籤定義的SQL語句,第一容易出錯,第二是當xml當中的id修改過後你不知道在程式當中有多少個地方使用了這個id,需要手動一一修改。後來Mybatis推出了Mapper動態代理方式,只需要編寫 Mapper介面 (相當於Dao層),由Mybatis框架根據介面定義建立介面的動態代理物件。
Mapper介面規範
- Mapper.xml中的namespace和Mapper.java介面中的類路徑相同,即
<mapper namespace="cn.ddnd.www.Dao.User">
對應的是cn.ddnd.www.Dao
包下的User
類。 - Mapper.xml中的
select
ID要和Mapper.java介面中的類方法名相同,即<select id="getUser" parameterType="String" resultType="User">
的getUser
和public User getUser(String email);
的getUser
方法名對應。 - Mapper.xml中的
parameterType
的型別要和Mapper介面中方法的 傳入引數型別 相同。 - Mapper.xml中的
resultType
的型別要和Mapper介面中方法的 返回引數型別 相同。
實現過程
配置Mapper.xml
IUser.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="cn.ddnd.www.Dao.IUser"> <select id="getUser" parameterType="String" resultType="User"> select * from user where email = #{email} </select> </mapper> 複製程式碼
配置Mapper.java介面
IUser.java:
package cn.ddnd.www.Dao; import cn.ddnd.www.Entity.User; public interface IUser { public User getUser(String email); } 複製程式碼
編寫Mybatis配置檔案
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> <typeAliases> <typeAlias type="cn.ddnd.www.Entity.User" alias="User"></typeAlias> </typeAliases> <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://127.0.0.1:3306/spring?serverTimezone=GMT%2B8" /> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments> <mappers> <mapper resource="cn/ddnd/www/Dao/IUser.xml"></mapper> </mappers> </configuration> 複製程式碼
測試類
test.java:
import cn.ddnd.www.Dao.IUser; import cn.ddnd.www.Entity.User; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import org.junit.Test; import org.apache.ibatis.io.Resources; import java.io.Reader; import java.io.IOException; public class test { private static Reader reader; private static SqlSessionFactory sqlSessionFactory; static{ try{ reader = Resources.getResourceAsReader("Mybatis-config.xml"); sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); }catch (IOException e){ e.printStackTrace(); } } @Test public void a() throws IOException { SqlSession sqlSession = sqlSessionFactory.openSession(); try{ IUser IUser = (IUser) sqlSession.getMapper(IUser.class); User user = IUser.getUser("[email protected]"); System.out.println("使用者的郵箱是:" + user.getEmail() + ",使用者的名稱是:" + user.getName() + ",使用者的密碼是:" + user.getPassword()); }finally { sqlSession.close(); } } } 複製程式碼
IUser IUser = (IUser) sqlSession.getMapper(IUser.class);
sqlSession會幫我們生成一個實現類(給IUser介面),這樣即可獲取IUser介面的代理物件。 User user = IUser.getUser("[email protected]");
代理物件方法。
轉自:ddnd.cn/2018/11/30/…