欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis接口式編程的原理

 更新時間:2017年03月15日 15:46:44   作者:Terence_Jing  
mybatis有兩種實現(xiàn)方式,一種可以通過xml配置文件實現(xiàn),其二是面向接口編程的實現(xiàn)。本文重點給大家介紹mybatis接口編程的原理,需要的的朋友參考下

Mybatis 有兩種實現(xiàn)方式

其一:通過xml配置文件實現(xiàn)

其二:面向接口編程的實現(xiàn)

           前者原理在Mybatis運行套路里面大致說了一下,此節(jié)說的是后者,面向接口的編程,可以解決掉 namespace / 傳入?yún)?shù) / 返回值 / 與Sql關(guān)聯(lián)Id 等四處風(fēng)險

           意思就是,Mybatis配置文件Dao.xml找了一個接口作為自己的代言人,并告訴其他的Java對象,以后訪問數(shù)據(jù)庫不要再騷擾我這個Dao.xml文件了,你去找我的代言人助理它會全權(quán)負(fù)責(zé)的。

           如果接口助理要全權(quán)負(fù)責(zé)Dao.xml文件的所有工作,那么,Dao.xml文件肯定要和代言接口交接清楚工作任務(wù),不能然接口亂搞。

仍舊以訪問數(shù)據(jù)庫信息列表為例:

首先要定義一個接口IMessage和Dao.xml文件里面的各種配置項一一對應(yīng):

package hdu.terence.dao; 
import java.util.List; 
import hdu.terence.bean.Message; 
public interface IMessage { 
    publicList<Message> queryMessageList(Message message); 
} 

Dao.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.terence.dao.IMessage">  
 <resultMap type="hdu.terence.bean.Message" id="MessageResult">  
  <id column="id" jdbcType="INTEGER"property="id"/> <!--主鍵標(biāo)簽--> 
  <result column="COMMAND" jdbcType="VARCHAR"property="command"/> 
  <result column="DESCRIPTION" jdbcType="VARCHAR" property="description"/> 
  <result column="CONTENT" jdbcType="VARCHAR"property="content"/> 
 </resultMap>   
 <select id="queryMessageList" parameterType="hdu.terence.bean.Message" resultMap="MessageResult"> 
  SELECTID,COMMAND,DESCRIPTION,CONTENT FROM message WHERE 1=1    
  <if test="command!=null and!"".equals(command.trim())"> 
  andCOMMAND=#{command} 
  </if> 
  <if test="description!=null and!"".equals(description.trim())"> 
  andDESCRIPTION like '%' #{description} '%' 
  </if>  
 </select><span style="color: teal; font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"> </span> 

測試:

public List<Message> queryMessageListByMybatis(Stringcommand,String description) 
  { 
    DBAccess dbAccess =new DBAccess(); 
    SqlSession sqlSession=null; 
    List<Message>messageList=new ArrayList<Message>(); 
    try { 
      sqlSession=dbAccess.getSqlSession(); 
      Message message=new Message(); 
      message.setCommand(command); 
      message.setDescription(description);           
      //方式二:通過接口調(diào)用配置文件里面的sql語句 
      IMessageimessage=sqlSession.getMapper(IMessage.class); 
      messageList=imessage.queryMessageList(message); 
    } catch (IOException e) { 
      e.printStackTrace(); 
    } 
    finally{ 
      if(sqlSession!=null) 
      { 
        sqlSession.close(); //要關(guān)閉數(shù)據(jù)庫會話 
      } 
    } 
    return messageList; 
  } 

            第一,Dao.xml文件命名空間要和接口的全名保持一致:寫接口的全名(包括報名com.terence.dao.IMessage)方便接口找到配置文件的命名空間。

            第二,接口定義代言的sql語句對應(yīng)的方法:queryMessageList(),方法名要和代言的sql語句配置項的id:queryMessageList相同,方便接口根據(jù)自己聲明的方法映射到對應(yīng)的配置項id。

            第三,接口聲明的方法帶入的形參Message要和Dao.xml文件對應(yīng)配置項需要的參數(shù)保持一致。

            第四,接口聲明的方法的返回值類型List<Message>要和Dao.xml文件id配置項resultMap類型一致。

            這樣就完成了接口的代理工作,配置文件會告訴其他的Java代碼,以后通過這個接口就可以完成我本來要完成的工作,執(zhí)行Sql語句對數(shù)據(jù)庫完成交互工作;很明顯,這種接口式編程比以前的直接調(diào)用配置文件方便多了,以前直接調(diào)用配置文件,每次使用配置文件,都需要寫配置文件的命名空間、id、參數(shù)和返回值,這些地方有時候會手滑寫不一致,如果出錯,編譯器不會出現(xiàn)提示,開發(fā)者只能根據(jù)執(zhí)行結(jié)果錯誤提示推敲錯誤的地方慢慢調(diào)試。如果使用接口式編程,通過將配置文件dao.xml和定義的接口一一匹配對應(yīng),通過接口代理配置文件,以后不管誰使用都可以直接調(diào)用接口下,不用管配置文件里面的命名空間和sql配置ID,調(diào)用接口時如果出錯,會自動提示,更有利于錯誤的查找。

            但是,如果僅僅在Mybatis中使用接口式編程,并沒有什么顯著的效果,但是當(dāng)Mybatis遇到spring的時候,效果就顯著了。

            當(dāng)Mybatis遇到Spring,Mybatis的核心配置文件Configuration.xml中連接數(shù)據(jù)庫的配置,就會取代了Spring中的DB層,Mybatis中的SqlSession會話將會托管給Spring,上述的MessageDao.xml部分帶入?yún)?shù)調(diào)用接口的部分都會托管給Spring的Service來完成。此時我們定義的IMessage接口將會替代原來的Dao層,此時的Dao層只剩下接口文件和JavaDao.xml配置文件. 

Mybatis接口式編程的原理

第一個問題,明天為什么接口Imssage.queryMessageList()沒有實現(xiàn)類,但是卻可以調(diào)用對應(yīng)的方法?

            首先要有一個創(chuàng)建代理實例的類,類里面有個方法invoke();

MapperProxy implements InvocationHandler
{
 MapperProxy.invoke();
}

            當(dāng)我們調(diào)用接口的時候,走的是Invoke()方法,會通過Proxy.NewProxyInstance()加載一個代理實例,實際上也就是通過sqlSession.getMapper()來獲取代理實例,即

sqlSession.getMapper()==Proxy.newProxyInstance(); 
IMessage imessage=sqlSession.getMapper(IMessage.class);
messageList=imessage.queryMessageList(message);

            這樣,即使IMessage自身沒有實現(xiàn)類,但是通過SqlSession的getMapper方法帶入接口類IMessage.class,就可以獲取一個IMessage類型的代理實例,很明顯,這里是泛型在起作用,帶入什么樣的類型,就得到一個什么類型的接口,原因是Mybatis已經(jīng)利用泛型做了強轉(zhuǎn)了; 

第二個問題,既然是通過invoke()方法,它是怎么知道我們要調(diào)用sqlSession.selectList()方法?

            因為剛初始化sqlSession的時候,加載了Configuration.xml文件,并在改文件中加載了各個JavaDao.xml文件,而這個Configuration.xml文件對應(yīng)了Mybatis中相關(guān)的類:Configuration,接口的全名稱在Invoke()方法里面都可以拿到, 接口全名稱.方法名==namespace.id,所以可以拿到配置文件中的查詢方法。 

SqlSession的獲取

public SqlSession getSqlSession() throws IOException 
{ 
    //1、通過配置文件獲取數(shù)據(jù)庫連接相關(guān)信息 
    Readerreader=Resources.getResourceAsReader("hdu/terence/config/Configuration.xml"); 
    //2、通過配置信息構(gòu)建SqlSessionFactory 
    SqlSessionFactorySSF=newSqlSessionFactoryBuilder().build(reader); 
    //3、通過SqlSessionFactory打開數(shù)據(jù)庫會話 
    SqlSessionsqlSession=SSF.openSession(); 
    return sqlSession; } 

    SqlSession通過上述配置實現(xiàn),首先通過Resources.getResourceAsReader(“配置文件路徑”)方法加載配置文件包裝一個reader對象,然后通過SqlSessionFactory這個接口帶入reader對象,獲取一個動態(tài)代理實例,即SqlSessionFactory會話工廠,通過會話工廠得到一個會話SqlSession().   

  其中,在獲取會話工廠獲取實例的時候,底層實現(xiàn)源碼是將帶入的參數(shù)read作為key,找到Map中對應(yīng)的value值,即MapperProxyFactory。

以上所述是小編給大家介紹的Mybatis接口式編程的原理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 帶你深入了解java-代理機制

    帶你深入了解java-代理機制

    Java 有兩種代理方式,一種是靜態(tài)代理,另一種是動態(tài)代理。如果我們在代碼編譯時就確定了被代理的類是哪一個,那么就可以直接使用靜態(tài)代理;如果不能確定,那么可以使用類的動態(tài)加載機制,在代碼運行期間加載被代理的類這就是動態(tài)代理
    2021-08-08
  • SpringBoot2線程池定義使用方法解析

    SpringBoot2線程池定義使用方法解析

    這篇文章主要介紹了SpringBoot2線程池定義使用方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • IDEA中使用Typora編輯md文件的方法

    IDEA中使用Typora編輯md文件的方法

    這篇文章主要介紹了IDEA中使用Typora編輯md文件的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • Java 代碼實例解析設(shè)計模式之監(jiān)聽者模式

    Java 代碼實例解析設(shè)計模式之監(jiān)聽者模式

    所謂監(jiān)聽者模式,我理解的是構(gòu)建一個容器存放所有被監(jiān)聽的線程或?qū)ο?,監(jiān)聽每個線程或?qū)ο蟀l(fā)生的變化,若某個線程或?qū)ο笥|發(fā)指定規(guī)則,那么則對所有被監(jiān)聽的線程或?qū)ο蟾鶕?jù)業(yè)務(wù)需要做處理
    2021-10-10
  • Java求s=a+aa+aaa+aaaa+aa...a 5個數(shù)相加的值

    Java求s=a+aa+aaa+aaaa+aa...a 5個數(shù)相加的值

    求s=a+aa+aaa+aaaa+aa...a的值,其中a是一個數(shù)字。例如2+22+222+2222+22222(此時共有5個數(shù)相加),幾個數(shù)相加有鍵盤控制
    2017-02-02
  • Java current并發(fā)包超詳細(xì)分析

    Java current并發(fā)包超詳細(xì)分析

    current并發(fā)包、在JDK1.5之前Java并沒有提供線程安全的一些工具類去操作多線程,需要開發(fā)人員自行編寫實現(xiàn)線程安全,但仍然無法完全避免低性能、死鎖、資源管理等問題。在JDK1.5時新增了java.util.current并發(fā)包,其中提供了許多供我們使用的并發(fā)編程工具類
    2023-02-02
  • Java語言實現(xiàn)簡單FTP軟件 FTP協(xié)議分析(1)

    Java語言實現(xiàn)簡單FTP軟件 FTP協(xié)議分析(1)

    這篇文章主要介紹了Java語言實現(xiàn)簡單FTP軟件的第一篇,針對FTP協(xié)議進行分析,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Java讀取TXT文件內(nèi)容的方法

    Java讀取TXT文件內(nèi)容的方法

    本篇文章主要介紹了Java讀取TXT文件內(nèi)容的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • spring boot日志管理配置

    spring boot日志管理配置

    這篇文章主要介紹了spring boot日志管理配置的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • java不同線程解讀以及線程池的使用方式

    java不同線程解讀以及線程池的使用方式

    這篇文章主要介紹了java不同線程解讀以及線程池的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08

最新評論