您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關mybatis相關介紹是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
創建SqlSessionFactory對象
通過SqlSessionFactory獲取sqlSession對象
通過sqlSession獲取Mapper的代理對象
通過mapper的代理對象,執行數據庫操作
執行成功,則使用sqlsession提交事務
執行失敗,則使用sqlsession回滾事務
最終,關閉會話
${}是properties文件中的變量占位符,它可以用于xml標簽屬性值和sql內部,屬于字符串替換。
<!-- ${driver} 會被替換為 com.mysql.jdbc.driver --> <dataSource type="UNPOOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> </dataSource>
${}也可以對傳遞進來的參數原樣拼接在sql中。實際場景中,不推薦使用${},因為會有sql注入的風險。
#{}是sql的參數占位符,mybatis會將sql中的#{}替換為?號,在sql執行前會使用PreparedStatement的參數設置方法,按序給sql的?號占位符設置參數。所以#{}是預編譯處理,可以有效防止sql注入,提高系統安全性。
第一種:通過在查詢的sql語句中定義字段別名,讓字段名的別名和實體類的屬性一致
第二種:在大多數場景下,數據庫的字段名和實體類的屬性名的差異,主要是一種是下劃線,一種是駝峰風格。這種情況,可以直接配置如下,實現自動的下劃線轉駝峰的功能。
<setting name="mapUnderscoreToCamelCase" value="true" />
第三種,通過<resultMap>來映射字段名和實體類屬性名的一一對應關系。
參考mybatis中文文檔
cache -對給定命名空間的緩存配置
cache-ref 對其他命名空間緩存配置的引用
resultMap 用來描述如何從數據庫結果集中來加載對象
sql 可被其他語句引用的可重用語句塊
參考mybatis中文文檔
<if/> 、<where/>、 <set/>、 <choose/>、 <foreach/>、<when/>、 <otherwise/>、<trim/>
不同的數據庫,獲取自動生成的主鍵的方式是不同的。mysql有兩種方式,代碼如下
// 方式一,使用 useGeneratedKeys + keyProperty 屬性 <insert id="insert" parameterType="Person" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user(name, pswd) VALUE (#{name}, #{pswd}) </insert> // 方式二,使用 `<selectKey />` 標簽 <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>
看完上述內容,你們對mybatis相關介紹是什么有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。