日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

【Java】Mybatis mapper动态代理方式

發布時間:2023/12/19 java 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Java】Mybatis mapper动态代理方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

我們在使用Mybatis的時候,獲取需要執行的SQL語句的時候,都是通過調用xml文件來獲取,例如:User user = (User) sqlSession.selectOne("cn.ddnd.www.Entity.User.getUser", "xue8@qq.com");。這種方式是通過字符串去調用標簽定義的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中的selectID要和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 configurationPUBLIC "-//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();}}@Testpublic void a() throws IOException {SqlSession sqlSession = sqlSessionFactory.openSession();try{IUser IUser = (IUser) sqlSession.getMapper(IUser.class);User user = IUser.getUser("xue8@qq.com");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("xue8@qq.com");代理對象方法。

    轉自:ddnd.cn/2018/11/30/…

    轉載于:https://juejin.im/post/5c0155096fb9a049d235c8e5

    總結

    以上是生活随笔為你收集整理的【Java】Mybatis mapper动态代理方式的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。