mybatis中注解與xml配置的對應關系和對比分析
注解與xml配置的對應關系
mybatis中注解就是簡單不需要寫配置文件,適合簡單的數(shù)據(jù)處理,理解起來比較容易,不動態(tài)生成SQL時候可以用用。
需要綁定,有些時候不如配置文件,配置文件擴展強。 選擇合適的方式應用在合適的場景,注解主要應用于sql語句比較簡單容易理解的情況下可讀性高;生成動態(tài)sql時用xml配置文件要更簡潔,擴展性強
常用的注解和xml的對應關系
@CacheNamespace
類 <cache>@CacheNamespaceRef
類 <cacheRef>@Results
方法 <resultMap>@Result
方法 <result> <id>@One
方法 <association>@Many
方法 <collection>@select
<select>@Insert
<insert>@Update
<update>@Delete
方法 <delete>@InsertProvider
<insert> 允許創(chuàng)建動態(tài)SQL@UpdateProvider
<update> 允許創(chuàng)建動態(tài)SQL@DeleteProvider
<delete> 允許創(chuàng)建動態(tài)SQL@SelectProvider
<select> 允許創(chuàng)建動態(tài)SQL@Param
參數(shù) N/A 如果你的映射器的方法需要多個參數(shù), 這個注解可以被應用于映射器的方法 參數(shù)來給每個參數(shù)一個名字。否則,多 參數(shù)將會以它們的順序位置來被命名 (不包括任何 RowBounds 參數(shù)) 比如。 #{param1} , #{param2} 等 , 這 是 默 認 的 。 使用 @Param(“person”),參數(shù)應該被命名為 #{person}。@Options
方法 映射語句的屬性 這個注解提供訪問交換和配置選項的 寬廣范圍, 它們通常在映射語句上作為 屬性出現(xiàn)。 而不是將每條語句注解變復 雜,Options 注解提供連貫清晰的方式 來訪問它們
注解樣例和xml配置樣例
舉幾個比較典型和常用的
一對一關聯(lián)查詢
注解方式
@Select("select * from authority") @Results(id="au", value=@Result(column="uid", property="user", one=@One(select="findUserByid", fetchType=FetchType.LAZY))) List<Authority> findAll();
@Select
里面填寫要查詢的主表的sql語句@Results
里面映射一個id="au"的返回結(jié)果集value=@Result()
表示某一屬性的映射關系column
為對應從表的外鍵名property
為主表實體類的從表實體類屬性名one
表示一對一映射fetchType=FetchType.LAZY
表示為惰性加載,當查詢的結(jié)構數(shù)據(jù)需要用到從表的數(shù)據(jù)才會調(diào)用select中的從表的查詢方法select
為關聯(lián)查詢的另一個從表的查詢方法uid
為select里的參數(shù)findUserByid
為mapper中定義的方法
@Select("select * from user where id = #{id}") User findUserByid(int id);
此方法可以在xml中配置也可以在本方法中用注解配置
xml中配置方式
<resultMap type="com.jt.mybatis.entity.Authority" id="au"> <association property="user" column="uid" javaType="com.jt.mybatis.entity.User" select="findByUserId"> </association> </resultMap> <select id="findAll" resultMap="au"> select * from authority </select> <select id="findUserByid" resultType="com.jt.mybatis.entity.User"> select * from user where id= #{id} </select>
測試方法
@Test public void testA(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); mapper.findAll().get(0).getUser(); }
一對多關聯(lián)查詢
xml配置方式
<resultMap type="com.jt.mybatis.entity.User" id="user"> <id column="id" property="id" /> <collection property="authoritieList" column="id" fetchType="lazy" select="findAuthorityByUid"> <id column="id" property="id" /> </collection> </resultMap> <select id="findUserByUserName" resultMap="user"> select * from user where username = #{username} </select> <select id="findAuthorityByUid" resultType="com.jt.mybatis.entity.Authority"> select * from authority where uid = #{uid} </select>
注解方式
@Select("select * from user where username = #{username}") @Results(id="user", value=@Result(column="id", property="authoritieList", many=@Many(fetchType=FetchType.LAZY, select="findAuthorityByUid"))) User findUserByUserName(String username); @Select("select * from authority where uid = #{uid}") List<Authority> findAuthorityByUid(int uid);
many表示一對多映射
測試方法
@Test public void testB(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); mapper.findUserByUserName("admin").getAuthoritieList(); }
動態(tài)sql
注解方式
@SelectProvider(type=AuthorityProvider.class,method="returnSelectSQL") List<Authority> findByIdAndUid(Authority authority); class AuthorityProvider{ public String returnSelectSQL(Authority authority){ SQL sql = new SQL(){{ SELECT("*"); FROM("authority"); if(authority.getId() != 0){ WHERE("id = " + authority.getId()); } if(authority.getUid() != 0){ WHERE("uid = " + authority.getUid()); } }}; return sql.toString(); } } //用XXXProvider的注解是動態(tài)生成sql語句的, //type=AuthorityProvider.class為生成動態(tài)語句的具體類 //method="returnSelectSQL"為生成動態(tài)語句的方法 //SQL類為動態(tài)生成sql的類
測試方法
@Test public void testC(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); Authority authority = new Authority(); mapper.findByIdAndUid(authority); //執(zhí)行此語句返回的sql語句為DEBUG [main] - ==> Preparing: SELECT * FROM authority authority.setId(1); mapper.findByIdAndUid(authority); //執(zhí)行此語句返回的sql語句為DEBUG [main] - ==> Preparing: SELECT * FROM authority WHERE (id = 1) authority.setUid(2); mapper.findByIdAndUid(authority); //執(zhí)行此語句返回的sql語句為DEBUG [main] - ==> Preparing: SELECT * FROM authority WHERE (id = 1 AND uid = 2) }
mybatis 注解和xml 優(yōu)缺點
xml:
增加了xml文件,修改麻煩,條件不確定(ifelse判斷),容易出錯,特殊轉(zhuǎn)義字符比如大于小于
注釋:
復雜sql不好用,搜集sql不方便,管理不方便,修改需重新編譯
#和$區(qū)別:
相同
- 都是對參數(shù)進行標記的符號
- #是預編譯,防止sql注入
- $ 相當于一個占位符,不能防止sql注入
小知識:
如果字段有關鍵字,則可以用反單引號修飾 比如desc-》`desc` 這樣就不會報錯了
resultType 只有和對象屬性一樣才能映射成功
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用Spring AntPathMatcher的doMatch方法
這篇文章主要介紹了使用Spring AntPathMatcher的doMatch方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09SpringBoot使用Mybatis-Generator配置過程詳解
這篇文章主要介紹了SpringBoot使用Mybatis-Generator配置過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-02-02Java Poi 在Excel中輸出特殊符號的實現(xiàn)方法
這篇文章主要介紹了Java Poi 在Excel中輸出特殊符號的實現(xiàn)方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07java求最大公約數(shù)與最小公倍數(shù)的方法示例
這篇文章主要介紹了java求最大公約數(shù)與最小公倍數(shù)的方法,涉及java數(shù)值運算的相關操作技巧,并附帶分析了eclipse環(huán)境下設置運行輸入?yún)?shù)的相關操作技巧,需要的朋友可以參考下2017-11-11Vue中computed計算屬性和data數(shù)據(jù)獲取方式
這篇文章主要介紹了Vue中computed計算屬性和data數(shù)據(jù)獲取方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03