中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

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

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

創(chuàng)新互聯(lián)專(zhuān)注于和林格爾企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站建設(shè),商城系統(tǒng)網(wǎng)站開(kāi)發(fā)。和林格爾網(wǎng)站建設(shè)公司,為和林格爾等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站,專(zhuān)業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專(zhuān)業(yè)和態(tài)度為您提供的服務(wù)

1.mybatis編程步驟

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

  2. 通過(guò)SqlSessionFactory獲取sqlSession對(duì)象

  3. 通過(guò)sqlSession獲取Mapper的代理對(duì)象

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

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

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

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

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

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

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

${}也可以對(duì)傳遞進(jìn)來(lái)的參數(shù)原樣拼接在sql中。實(shí)際場(chǎng)景中,不推薦使用${},因?yàn)闀?huì)有sql注入的風(fēng)險(xiǎn)。


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

3.實(shí)體類(lèi)的屬性名和表中的字段名不一樣,如何處理

  • 第一種:通過(guò)在查詢的sql語(yǔ)句中定義字段別名,讓字段名的別名和實(shí)體類(lèi)的屬性一致

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

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

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

參考mybatis中文文檔

  • cache -對(duì)給定命名空間的緩存配置

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

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

  • sql 可被其他語(yǔ)句引用的可重用語(yǔ)句塊

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

參考mybatis中文文檔

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

6.如何獲取自動(dòng)生成的主鍵

不同的數(shù)據(jù)庫(kù),獲取自動(dòng)生成的主鍵的方式是不同的。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)容,你們對(duì)mybatis相關(guān)介紹是什么有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

名稱欄目:mybatis相關(guān)介紹是什么
文章轉(zhuǎn)載:http://www.rwnh.cn/article0/gshsio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈網(wǎng)站策劃、網(wǎng)站改版、云服務(wù)器、自適應(yīng)網(wǎng)站、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
壶关县| 柳江县| 通渭县| 巴彦淖尔市| 清苑县| 遵义市| 长宁区| 济宁市| 肇州县| 青浦区| 中山市| 隆昌县| 遂川县| 简阳市| 华安县| 清水河县| 梅州市| 武威市| 高密市| 堆龙德庆县| 庆城县| 惠来县| 深水埗区| 沈阳市| 含山县| 米易县| 玉树县| 且末县| 耒阳市| 仙居县| 南漳县| 迭部县| 平凉市| 龙州县| 永和县| 郁南县| 宜兴市| 临夏县| 灵宝市| 望城县| 灵宝市|