Mybatis常用標簽及屬性小結
一、常用標簽、動態(tài)Sql
select標簽:
<select id="findUserById" parameterType="int" resultMap="userResultMap">
<include refid="sqlMsg"><property name="id" /></include>
</select>
<sql id="sqlMsg"> SELECT * FROM User WHERE ID = #{id}</sql>
<resultMap id="userResultMap" type="User">
<id property="id" column="user_id" />
<result property="username" column="user_name"/>
<result property="password" column="hashed_password"/>
</resultMap>
insert標簽:
<insert id="addUser">
insert into User (id,name) values (#{id},#{name})
</insert>update標簽:
<update id="updateUser">
update User set
username = #{username},
password = #{password}
where id = #{id}
</update>delete標簽:
<delete id="deleteUser">
delete from User where id = #{id}
</delete>if標簽:
<select id="findUser" >
SELECT * FROM User
WHERE state = 0
<if test="name != null and name!=''">
AND name = #{name}
</if>
</select>choose、when、otherwise(類似于switch)標簽:
<select id="findUser" >
SELECT * FROM User WHERE state = 0
<choose>
<when test="name != null">
AND name like #{name}
</when>
<when test="age != null">
AND age = #{age}
</when>
<otherwise>
AND name like ''
</otherwise>
</choose>
</select>trim、where標簽:
<select id="getUser" resultType="user">
select * from user
<trim prefix="where" prefixOverrides="and">
<if test="lastName != null">
name = #{name}
</if>
<if test="age != null">
and age = #{age}
</if>
<if test="phone != null">
and phone = #{phone}
</if>
</trim>
</select>foreach標簽:
<select id="queryUsers" >
select * from user where id in
<foreach collection="array" item="item" open="(" separator="," close=")" index="index">
#{item}
</foreach>
</select>bind標簽:
<!--使用bind元素進行模糊查詢-->
<select id="queryUserByName" resultType="com.MyUser" parameterType= "com.MyUser">
select * from user
<trim prefix="where" prefixOverrides="and">
<if test="name != null">]
<bind name="bindName" value="'%' + name + '%'"/>
name like #{bindName}
</if>
</trim>
</select>selectKey標簽:
<insert id="insert">
<selectKey keyProperty="id" resultType="int" order="BEFORE">
<!-- Oracle中用Sequence獲取主鍵 -->
<if test="_databaseId == 'oracle'">
select seq_users.nextval from dual
</if>
<!-- Mysql直接用sql查詢最大主鍵 -->
<if test="_databaseId == 'mysql'">
select(select max(u.id)+1 from t_user u)
</if>
</selectKey>
insert into t_user values (#{id}, #{name})
</insert>typeAliases標簽
<typeAliases>
<typeAlias alias="myAuthor" type="com.bean.Author"/>
<typeAlias alias="myUser" type="com.bean.User"/>
<typeAlias alias="myCar" type="com.bean.Car"/>
<typeAlias alias="myHouse" type="com.bean.House"/>
</typeAliases>
<select id="selectUser" lang="myUser">
SELECT * FROM user
</select>二、常用標簽屬性
select標簽屬性:
id 必選屬性,綁定Sql語句與Mapper接口中的方法,。
parameterType 傳入?yún)?shù)的類全限定名或別名。MyBatis 可以通過類型處理器(TypeHandler)推斷出具體傳入語句的參數(shù),默認值為未設置(unset)。
resultType 返回結果的類全限定名或別名。返回的是集合,則設置為集合包含的類型。
resultMap 對外部 resultMap 的命名引用。resultType 和 resultMap 之間只能同時使用一個。
flushCache 設為 true 后,只要語句被調(diào)用,會導致本地緩存和二級緩存被清空,默認值(對select):false。
useCache 設為 true 后,將會導致本條語句的結果被二級緩存緩存起來,默認值:對 select 元素為 true。
timeout 等待數(shù)據(jù)庫返回請求結果的秒數(shù)。默認值為未設置(unset)(依賴數(shù)據(jù)庫驅(qū)動)。
fetchSize 給驅(qū)動的建議值,讓驅(qū)動程序每次批量返回的結果行數(shù)等于這個設置值。默認不設置(unset)(依賴驅(qū)動)。
statementType 可選 STATEMENT、PREPARED、CALLABLE。讓 MyBatis 分別使用 Statement、PreparedStatement、CallableStatement,默認:PREPARED。
resultSetType 可選 FORWARD_ONLY、SCROLL_SENSITIVE、SCROLL_INSENSITIVE 或 DEFAULT(等價于 unset),默認值為 unset (依賴數(shù)據(jù)庫驅(qū)動)。
databaseId 如果配置了數(shù)據(jù)庫廠商標識(databaseIdProvider),MyBatis 會加載不帶 databaseId 屬性和帶有匹配當前數(shù)據(jù)庫 databaseId 屬性的所有語句;如果帶和不帶的語句都有,不帶的會被忽略。
resultOrdered 僅針對嵌套結果 select 語句: 若為 true,將會假設包含了嵌套結果集或分組,返回一個主結果行時,不會產(chǎn)生對前面結果集的引用。獲取嵌套結果集的時不至于內(nèi)存不夠,默認:false。
resultSets 僅適用于多結果集的情況。返回多個結果集并賦予每個結果集一個名稱,多個名稱之間以逗號分隔。insert、update、delete標簽屬性:
id 必選屬性,綁定Sql語句與Mapper接口中的方法,。
parameterType 傳入?yún)?shù)的類全限定名或別名。MyBatis 可以通過類型處理器(TypeHandler)推斷出具體傳入語句的參數(shù),默認值為未設置(unset)。
flushCache 設為 true 后,只要語句被調(diào)用,會導致本地緩存和二級緩存被清空,默認值:(對 insert、update 和 delete 語句)true。
timeout 等待數(shù)據(jù)庫返回請求結果的秒數(shù)。默認值為未設置(unset)(依賴數(shù)據(jù)庫驅(qū)動)。
statementType 可選 STATEMENT、PREPARED、CALLABLE。讓 MyBatis 分別使用 Statement、PreparedStatement、CallableStatement,默認:PREPARED。
databaseId 如果配置了數(shù)據(jù)庫廠商標識(databaseIdProvider),MyBatis 會加載不帶 databaseId 屬性和帶有匹配當前數(shù)據(jù)庫 databaseId 屬性的所有語句;如果帶和不帶的語句都有,不帶的會被忽略。
useGeneratedKeys (僅insert、update)會令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法來取出由數(shù)據(jù)庫內(nèi)部生成的主鍵,默認值:false。
keyProperty (僅insert、update)指定能夠唯一識別對象的屬性,用 getGeneratedKeys 的返回值或 insert 語句的 selectKey 子元素設置它的值,默認:未設置(unset)??捎枚禾柗指舳鄠€屬性名。
keyColumn (僅insert、update)設置生成鍵值在表中的列名,當主鍵列不是表中的第一列的時候,必須設置。如果生成列不止一個,可用逗號分隔多個屬性名。trim標簽屬性:
prefix 拼接前綴。
suffix 拼接后綴。
prefixOverrides 去除sql語句前面的關鍵字或者字符。
suffixOverrides 去除sql語句后面的關鍵字或者字符。foreach標簽屬性:
collection 表示迭代集合的名稱,可以使用@Param注解指定。
item 必選參數(shù),集合中元素迭代時的別名。
index 在list和數(shù)組中,index是元素的序號,在map中,index是元素的key。
open foreach代碼的開始符號,一般是(和close=")"合用。
close foreach代碼的關閉符號,一般是)和open="("合用。
separator 元素之間的分隔符,separator=","會自動在元素中間用“,“。selectKey標簽屬性:
keyProperty 返回目標結果的key。
resultType 結果的類型。
order 設置為BEFORE或AFTER,設置為BEFORE,會先選擇主鍵設置keyProperty,然后執(zhí)行插入語句;設為AFTER,先執(zhí)行插入語句,然后設置selectKey元素。
statementType 和前面的相同,MyBatis 支持 STATEMENT、PREPARED、CALLABLE語句的映射類型,分別代表PreparedStatement、CallableStatement 類型。到此這篇關于Mybatis常用標簽及屬性的文章就介紹到這了,更多相關Mybatis常用標簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
spring boot整合spring-kafka實現(xiàn)發(fā)送接收消息實例代碼
這篇文章主要給大家介紹了關于spring-boot整合spring-kafka實現(xiàn)發(fā)送接收消息的相關資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來看看吧。2017-06-06
Java的Flowable工作流之加簽轉(zhuǎn)簽詳解
這篇文章主要介紹了Java的Flowable工作流之加簽轉(zhuǎn)簽詳解,Flowable是一個開源的工作流引擎,它提供了一套強大的工具和功能,用于設計、執(zhí)行和管理各種類型的工作流程,需要的朋友可以參考下2023-11-11
Java如何讀寫Properties配置文件(Properties類)
這篇文章主要介紹了Java如何讀寫Properties配置文件(Properties類),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05

