溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mybatis相關(guān)介紹是什么

發(fā)布時間:2021-10-19 17:38:35 來源:億速云 閱讀:113 作者:柒染 欄目:大數(shù)據(jù)

今天就跟大家聊聊有關(guān)mybatis相關(guān)介紹是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

1.mybatis編程步驟

  1. 創(chuàng)建SqlSessionFactory對象

  2. 通過SqlSessionFactory獲取sqlSession對象

  3. 通過sqlSession獲取Mapper的代理對象

  4. 通過mapper的代理對象,執(zhí)行數(shù)據(jù)庫操作

  5. 執(zhí)行成功,則使用sqlsession提交事務(wù)

  6. 執(zhí)行失敗,則使用sqlsession回滾事務(wù)

  7. 最終,關(guān)閉會話

2.#{}和${}的區(qū)別

${}是properties文件中的變量占位符,它可以用于xml標(biāo)簽屬性值和sql內(nèi)部,屬于字符串替換。

<!-- ${driver} 會被替換為 com.mysql.jdbc.driver -->
<dataSource type="UNPOOLED">
    <property name="driver" value="${driver}"/>
    <property name="url" value="${url}"/>
    <property name="username" value="${username}"/>
</dataSource>

${}也可以對傳遞進來的參數(shù)原樣拼接在sql中。實際場景中,不推薦使用${},因為會有sql注入的風(fēng)險。


#{}是sql的參數(shù)占位符,mybatis會將sql中的#{}替換為?號,在sql執(zhí)行前會使用PreparedStatement的參數(shù)設(shè)置方法,按序給sql的?號占位符設(shè)置參數(shù)。所以#{}是預(yù)編譯處理,可以有效防止sql注入,提高系統(tǒng)安全性。

3.實體類的屬性名和表中的字段名不一樣,如何處理

  • 第一種:通過在查詢的sql語句中定義字段別名,讓字段名的別名和實體類的屬性一致

  • 第二種:在大多數(shù)場景下,數(shù)據(jù)庫的字段名和實體類的屬性名的差異,主要是一種是下劃線,一種是駝峰風(fēng)格。這種情況,可以直接配置如下,實現(xiàn)自動的下劃線轉(zhuǎn)駝峰的功能。

    <setting name="mapUnderscoreToCamelCase" value="true" />
  • 第三種,通過<resultMap>來映射字段名和實體類屬性名的一一對應(yīng)關(guān)系。

4.mybatis的xml映射文件中,除了常見的select|insert|update|delete標(biāo)簽外,還有哪些標(biāo)簽

參考mybatis中文文檔

  • cache -對給定命名空間的緩存配置

  • cache-ref 對其他命名空間緩存配置的引用

  • resultMap 用來描述如何從數(shù)據(jù)庫結(jié)果集中來加載對象

  • sql 可被其他語句引用的可重用語句塊

5.mysql的動態(tài)sql有哪些

參考mybatis中文文檔

<if/> 、<where/>、 <set/>、 <choose/>、 <foreach/>、<when/>、 <otherwise/>、<trim/>

6.如何獲取自動生成的主鍵

不同的數(shù)據(jù)庫,獲取自動生成的主鍵的方式是不同的。mysql有兩種方式,代碼如下

// 方式一,使用 useGeneratedKeys + keyProperty 屬性
<insert id="insert" parameterType="Person" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO user(name, pswd)
    VALUE (#{name}, #{pswd})
</insert>
    
// 方式二,使用 `<selectKey />` 標(biāo)簽
<insert id="insert" parameterType="Person" useGeneratedKeys="true" keyProperty="id">
    <selectKey keyProperty="id" resultType="long" order="AFTER">
        SELECT LAST_INSERT_ID()
    </selectKey>
        
    INSERT INTO user(name, pswd)
    VALUE (#{name}, #{pswd})
</insert>

看完上述內(nèi)容,你們對mybatis相關(guān)介紹是什么有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI