MyBatis学习Day2

MyBatis动态SQL

choose,when,otherwise

MyBatis 中动态语句 choose-when-otherwise 类似于 Java 中的 switch-case-default 语句。由于 MyBatis 并没有为 if 提供对应的 else 标签,如果想要达到<if>...<else>...</else> </if> 的效果,可以借助 <choose>、<when>、<otherwise> 来实现。

<choose>
				<when test='salarytext=="低"'>
					salary &lt;= 10000
				</when>
				<when test='salarytext=="中"'>
					salary &gt; 10000 and salary&lt;= 20000
				</when>
				<otherwise>
					salary &gt; 20000
				</otherwise>
			</choose>

if

MyBatis if 类似于 Java 中的 if 语句。

<if test="checktext !=null and checktext !=''">
				<!-- 重新定义参数内容 -->
				<bind value="'%'+checktext+'%'" name="liketext"></bind>
				name like #{liketext}
			</if>

where

where 标签主要用来简化 SQL 语句中的条件判断,可以自动处理 AND/OR 条件。

foreach

foreach 标签用于循环语句,它很好的支持了数组和 List、set 接口的集合,并对此提供遍历的功能。

foreach 标签主要有以下属性
    item:表示集合中每一个元素进行迭代时的别名。
    index:指定一个名字,表示在迭代过程中每次迭代到的位置。
    open:表示该语句以什么开始(既然是 in 条件语句,所以必然以(开始)。
    separator:表示在每次进行迭代之间以什么符号作为分隔符(既然是 in 条件语句,所以必然以,作为分隔符)。
    close:表示该语句以什么结束(既然是 in 条件语句,所以必然以)开始)。

注意
    使用 foreach 标签时,最关键、最容易出错的是 collection 属性,该属性是必选的,但在不同情况下该属性的值是不一样的,主要有以下 3 种情况:
    如果传入的是单参数且参数类型是一个 List,collection 属性值为 list。
    如果传入的是单参数且参数类型是一个 array 数组,collection 的属性值为 array。
    如果传入的参数是多个,需要把它们封装成一个 Map,当然单参数也可以封装成 Map。Map 的 key 是参数名,collection 属性值是传入的 List 或 array 对象在自己封装的 Map 中的 key。

	<insert id="addList">
		insert into staff (code,name,salary,username,userpass) values
		<foreach collection="list" item="it" separator=",">
			(#{it.code},#{it.name},#{it.salary},#{it.username},#{it.userpass})
		</foreach>
	</insert>

bind

bind 标签可以通过 OGNL [对象导航图语言(Object Graph Navigation Language)]表达式自定义一个上下文变量。

set

在 Mybatis 中,update 语句可以使用 set 标签动态更新列。set 标签可以为 SQL 语句动态的添加 set 关键字,剔除追加到条件末尾多余的逗号。

<update id="editStaffItem">
		update staff
		<set>
			<if test='name!=null and name!=""'>
				name=#{name},
			</if>
			<if test="salary!=null">
				salary=#{salary},
			</if>
		</set>
		<where>
			id=#{id}
		</where>
	</update>

resultMap

resultMap 是 MyBatis 中最复杂的元素,主要用于解决实体类属性名与数据库表中字段名不一致的情况,可以将查询结果映射成实体对象。

	<resultMap type="com.easy.bean.Dept" id="departmentAndStaff">
		<!-- <id column="id" property="depid"></id> <result column="name" property="depname"></result> -->
		<result column="id" property="id"></result>
		<collection fetchType="lazy" column="id" select="getDepStaff"
			property="staffList"></collection>
	</resultMap>

一对一关联查询

通过 <resultMap> 元素的子元素 <association> 处理一对一级联关系
<association> 元素中通常使用以下属性。
property:指定映射到实体类的对象属性。
column:指定表中对应的字段(即查询返回的列名)。
javaType:指定映射到实体对象属性的类型。
select:指定引入嵌套查询的子 SQL 语句,该属性用于关联映射中的嵌套查询。

一对多关联查询
通过 <resultMap> 元素的子元素 <collection> 处理一对多级联关系,collection 可以将关联查询的多条记录映射到一个 list 集合属性中。
<collection> 元素中通常使用以下属性。
property:指定映射到实体类的对象属性。
column:指定表中对应的字段(即查询返回的列名)。
javaType:指定映射到实体对象属性的类型。
select:指定引入嵌套查询的子 SQL 语句,该属性用于关联映射中的嵌套查询。

resultType和resultMap的区别
MyBatis 的每一个查询映射的返回类型都是 resultMap,只是当我们提供的返回类型是 resultType 时,MyBatis 会自动把对应的值赋给 resultType 所指定对象的属性,而当我们提供的返回类型是 resultMap 时,MyBatis 会将数据库中的列数据复制到对象的相应属性上,可用于复制查询。

MyBatis缓存(一级缓存和二级缓存)

MyBatis 提供了一级缓存和二级缓存的支持。默认情况下,MyBatis 只开启一级缓存。

一级缓存
一级缓存是基于 PerpetualCache(MyBatis自带)的 HashMap 本地缓存,作用范围为 SQLession 域内。当 session flush(刷新)或者 close(关闭)之后,该 session 中所有的 cache(缓存)就会被清空。
在参数和 SQL 完全一样的情况下,我们使用同一个 SqlSession 对象调用同一个 mapper 的方法,往往只执行一次 SQL。因为使用 SqlSession 第一次查询后,MyBatis 会将其放在缓存中,再次查询时,如果没有刷新,并且缓存没有超时的情况下,SqlSession 会取出当前缓存的数据,而不会再次发送 SQL 到数据库。
由于 SqlSession 是相互隔离的,所以如果你使用不同的 SqlSession 对象,即使调用相同的 Mapper、参数和方法,MyBatis 还是会再次发送 SQL 到数据库执行,返回结果。

二级缓存
    二级缓存是全局缓存,作用域超出 SQLsession 范围之外,可以被所有 SqlSession 共享。手动开启

<!-- 开启二级缓存 -->
	<cache eviction="FIFO" flushInterval="60000" size="512"
		readOnly="true" />


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值