【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接口規范

  1. Mapper.xml中的namespace和Mapper.java接口中的類路徑相同,即<mapper namespace="cn.ddnd.www.Dao.User">對應的是cn.ddnd.www.Dao包下的User類。
  2. Mapper.xml中的selectID要和Mapper.java接口中的類方法名相同,即<select id="getUser" parameterType="String" resultType="User">getUserpublic User getUser(String email);getUser方法名對應。
  3. Mapper.xml中的parameterType的類型要和Mapper接口中方法的傳入參數類型相同。
  4. 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

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450118.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450118.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450118.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

git pull時沖突的幾種解決方式

僅結合本人使用場景&#xff0c;方法可能不是最優的 1. 忽略本地修改&#xff0c;強制拉取遠程到本地 主要是項目中的文檔目錄&#xff0c;看的時候可能多了些標注&#xff0c;現在遠程文檔更新&#xff0c;本地的版本已無用&#xff0c;可以強拉 git fetch --allgit reset --h…

Android應用開發—eventBus發布事件和事件處理的時序關系

占坑&#xff0c;簡單說明下eventBus發布事件和事件處理的時序關系。 什么時候使用sticky&#xff1a; 當你希望你的事件不被馬上處理的時候&#xff0c;舉個栗子&#xff0c;比如說&#xff0c;在一個詳情頁點贊之后&#xff0c;產生一個VoteEvent&#xff0c;VoteEvent并不立…

grep命令 解說

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 grep&#xff08;global search regular expression(RE) and print out the line&#xff0c;全面搜索正則表達式并把行打印出來&#x…

創業第一桶金怎么來

文章摘要&#xff1a;資金是創業要具備的一個必要條件&#xff0c;那么對于創業者來說&#xff0c;第一桶金如何取得&#xff1f;資金是創業要具備的一個必要條件&#xff0c;那么對于創業者來說&#xff0c;第一桶金如何取得&#xff1f;   一、一門手藝   都說擁有萬貫…

4001.基于雙向鏈表的雙向冒泡排序法

基于雙向鏈表的雙向冒泡排序法 發布時間: 2018年11月26日 10:09 時間限制: 1000ms 內存限制: 128M 習題集源碼中出現了 temp->next->prior p; 本人推斷這里缺少預先的對temp->nextNULL這種情況的判定&#xff0c;所以需加入一個判斷語句解決。 此為非循環的雙向鏈…

頁面向上滾動

#頁面或者div向上無縫滾動 1.css: body {margin: 0;padding: 0;overflow: hidden;}.container {position: relative;top: 0;}.container div {width: 500px;height: 500px;border: 1px solid chartreuse;font-size: 100px;line-height: 500px;font-weight: bold;color: black;t…

叨逼叨

此處記錄點零散的小idea&#xff0c;為了避免把csdn當微博&#xff0c;開一篇&#xff0c;都記在這里吧。 感覺服務注冊機制&#xff0c;貌似也是一種依賴注入。&#xff08;雖然我還沒完全搞懂依賴注入&#xff09;&#xff0c;理由呢&#xff1a;你需要一個模塊的功能&#x…

Linux:echo命令詳解

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 echo命令 用于字符串的輸出 格式 echo string使用echo實現更復雜的輸出格式控制 1.顯示普通字符串: echo "It is a test"這里…

看年輕人如何賺第一桶金

上世紀90年代&#xff0c;成為百萬富翁&#xff0c;對很多人只是個夢想。不過如今&#xff0c;隨著經濟飛速發展&#xff0c;擁有百萬資產已經不再是神話&#xff0c;放眼望去&#xff0c;我們身邊的百萬富翁比比皆是&#xff0c;甚至很多初入社會、白手起家的年輕人&#xff0…

跨越解決方案之nginx

這里是修真院前端小課堂&#xff0c;每篇分享文從 【背景介紹】【知識剖析】【常見問題】【解決方案】【編碼實戰】【擴展思考】【更多討論】【參考文獻】 八個方面深度解析前端知識/技能&#xff0c;本篇分享的是&#xff1a; 【跨越解決方案之nginx】 1.背景介紹 跨域&#x…

學習 shell腳本之前的基礎知識

見 : http://www.92csz.com/study/linux/12.htm【什么是shell】 簡單點理解&#xff0c;就是系統跟計算機硬件交互時使用的中間介質&#xff0c;它只是系統的一個工具。實際上&#xff0c;在shell和計算機硬件之間還有一層東西那就是系統內核了。打個比方&#xff0c;如果把計算…

「分塊系列」數列分塊入門3 解題報告

數列分塊入門3 題意概括 區間加法&#xff0c;區間求前驅。 寫在前面 這題的方法與分塊2方法極其類似&#xff0c;建議自行解決。 正題 和上一題類似&#xff0c;但是二分不是用來計數的&#xff0c;而是用來求小于c的最大值的。然后對于不完整快&#xff0c;將小于c的值求最大…

創業者自述:我的第一桶金是如何來的

記者采訪王宏筠的當天&#xff0c;北京氣溫已達到30℃&#xff0c;王宏筠從他的鐵灰色奧迪A6車上下來&#xff0c;一身挺括的西裝&#xff0c;打著領帶&#xff0c;肩上背著一個超大的牛皮包。后來他對記者說&#xff0c;穿西服是因為多年在外企養成的習慣&#xff0c;一年中至…

Git cherry-pick后再merge出現一個“奇怪”的現象

背景描述&#xff1a;有的時候基于一個master branch拉出一個獨立feature分支做開發時&#xff0c;兩條分支都在并行開發&#xff0c;如果master分支增加了某些功能&#xff0c;解決了某些關鍵bug&#xff0c;而獨立feature分支不需要所有的增加的commit&#xff0c;只需要某一…

inux系統中如何進入退出vim編輯器

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 VIM編輯器&#xff0c;可以新建文件也可以修改文件&#xff0c;命令為&#xff1a;vim AAA 。AAA就是文件名。 如果這個文件&#xff…

C++ 智能指針六

/* 智能指針unique_ptr */#include <iostream> #include <string> #include <memory> #include <vector>/*unique_ptr 獨占所指向的對象, 同一時刻只能有一個 unique_ptr 指向給定對象(通過禁止拷貝語義, 只有移動語義來實現), 定義于 memory (非memo…

如何掘到第一桶金

第一種類型&#xff1a;才智高遠型 典型代表&#xff1a;《福布斯》中國富豪榜排名第一位、個人資產總計達到83億元的中國希望集團劉氏兄弟。 與一般的創業者不同&#xff0c;劉氏四兄弟劉永言、劉永行、劉永美、劉永好一開始就悟透了“舍得”二字。他們本來都在國家企事業單…

Sublime Text3中文環境設置

Sublime Text3中文環境設置 1、首先打開安裝好的的Sublime軟件,選擇Preferences下面的Package Contorol選項出現彈窗方框 2、在彈窗輸入install package,選擇對應&#xff08;默認第一個&#xff0c;如圖這個&#xff09;命令點擊進入;安裝的時候&#xff0c;左下角會有進度條顯…

C/C++圖形化編程(2)

歸納編程學習的感悟&#xff0c; 記錄奮斗路上的點滴&#xff0c; 希望能幫到一樣刻苦的你&#xff01; 如有不足歡迎指正&#xff01; 共同學習交流&#xff01; &#x1f30e;歡迎各位→點贊 &#x1f44d; 收藏? 留言?&#x1f4dd; 站在巨人的肩上是為了超過巨人&#x…

Git clone之后你的硬盤上究竟發生了什么?

網上關于Git的使用有太多的博客&#xff0c;文章在講解了&#xff0c;大部分是在講解命令的用法&#xff0c;剩下一部分則在講解git的內部原理&#xff0c;看過講解基礎命令使用的文章后&#xff0c;正常的開發使用是沒有什么問題的了&#xff0c;而如果想更深入的了解git“高級…