动态sql

1、MyBatis 令人喜欢的一大特性就是动态 SQL。在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的。MyBatis 动态 SQL 的出现, 解决了这个麻烦。

MyBatis通过 OGNL 来进行动态 SQL 的使用的。目前, 动态 SQL 支持以下几种标签:

2、 if 标签

if 标签是我们最常使用的。在查询、删除、更新的时候很可能会使用到。必须结合 test 属性联合使用。

例如:

<select id="getEmpById2" resultType="emp"> 
		SELECT * FROM emp WHERE 1=1
		<if test="empno != null">
			AND empno = #{empno}
		</if>   
	</select>

 如果empno不为空,则在WHERE参数后加上AND empno = #{empno},这里有1=1所以即使empno为null,WHERE后面也不会报错。

此 if 标签的 test 属性值是一个符合 OGNL 的表达式, 表达式可以是 true 或 false。如果表达式返回的是数值, 则0为 false, 非 0 为 true;

 在此 SQL 语句中, where 1=1 是多条件拼接时的小技巧, 后面的条件查询就可以都用 and 了。

有时候我们并不想应用所有的条件,而只是想从多个选项中选择一个。而使用if标签时,只要test中的表达式为 true,就会执行 if 标签中的条件。MyBatis 提供了 choose 元素。if标签是与(and)的关系,而 choose 是或(or)的关系。

3.where语句和Choose(when,otherwise)

1.Where后面empno和ename为null,那where就不会出现在sql语句中。

2. choose标签是按顺序判断其内部when标签中的test条件出否成立,如果有一个成立,则 choose 结束。当 choose 中所有 when 的条件都不满则时,则执行 otherwise 中的sql。类似于Java 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。

<select id="getEmpById3" resultType="emp" parameterType="emp">
		SELECT * FROM EMP 
		<where>
			<choose>
				<when test="empno != null">
					AND empno like #{empno}
				</when>
				<when test="ename != null">
					AND ename like #{ename}
				</when>
				<otherwise>
					AND  job = "zz"
				</otherwise>
			</choose>
		</where>
	</select>

4.set语句

set主要也是用来解决更新问题的。

例如:

<update id="updateEmprById2" parameterType="emp">
		UPDATE emp
		<set>
			<if test="ename!=null"> ename=#{ename},</if>
			<if test="job!=null"> job=#{job},</if>
		</set>
		<where>
			<if test="empno!=null">
				empno=#{empno};
			</if>
		</where>
	</update>

5.trim

trim标记是一个格式化的标记,可以完成set或者是where标记的功能。
相关属性:
Prefix:前缀。
prefixOverrides:去掉第一个指定内容。
suffix:后缀。
suffixoverride:去掉最后一个指定内容。

<!-- 代替where -->
	<select id="getEmpById4" resultType="emp" parameterType="emp">
		SELECT * FROM emp
		<!-- <where> <if test="username!=null"> and name = #{username} </if> </where> -->
		<trim prefix="where" prefixOverrides="AND |OR ">
			<if test="empno != null">
				and empno = #{empno}
			</if>
			<if test="ename!=null">
				AND ename = #{ename}
			</if>
		</trim>
	</select>
<!-- 代替set -->
	<update id="updateEmprById3" parameterType="emp">
		update emp
		<trim prefix="set" suffixOverrides=",">
			<if test="ename!=null">
				ename = #{ename},
			</if>
			<if test="job != null">
				job = #{job}
			</if>
		</trim>
		<trim prefix="where" prefixOverrides="AND |OR ">
			<if test="empno != null">
				and empno = #{empno}
			</if>
		</trim>
	</update>

6.foreach语句

foreach用来遍历,遍历的对象可以是数组,也可以是集合。
相关属性:
Collection:collection属性的值有三个分别是list、array、map三种。
Open:前缀。
Close:后缀。
Separator:分隔符,表示迭代时每个元素之间以什么分隔。
Item:表示在迭代过程中每一个元素的别名。
Index:用一个变量名表示当前循环的索引位置。

例如:

<insert id="addEmp6">  
 insert into emp(ename,job)values  
 <foreach collection="emps" item="emp" separator=","> 
 (#{emp.ename},#{emp.job})   </foreach>  </insert>

7.SQL块

例如;

<!-- 定义重复使用的SQL内容 -->
	<sql id="baseSql">
		empno,ename,job
	</sql>
	
	<!-- 使用include引入sql块 -->
	<select id="selEmp1" resultType="emp">
		select 
		<include refid="baseSql"/>
		 from emp 
	</select>

8.bind

例如:

<select id="getEmpById6" resultType="emp">
		<!-- 声明了一个参数empno 在后面就可以使用了 -->
		<bind name="empno" value="7975" />
		select * from emp where empno=${empno}
	</select>

动态sql语句基本语法 1 :普通SQL语句可以用Exec执行 例: Select * from tableName Exec('select * from tableName') Exec sp_executesql N'select * from tableName' -- 请注意字符串前一定要加N 2:字段名,表名,数据库名之类作为变量时,必须用动态SQL 错误: declare @fname varchar(20) set @fname = 'FiledName' Select @fname from tableName -- 错误,不会提示错误,但结果为固定值FiledName,并非所要。 正确: Exec('select ' + @fname + ' from tableName') -- 请注意加号前后的单引号的边上加空格 当然将字符串改成变量的形式也可 declare @fname varchar(20) set @fname = 'FiledName' --设置字段名 declare @s varchar(1000) set @s = 'select ' + @fname + ' from tableName' Exec(@s) -- 成功 exec sp_executesql @s -- 此句会报错 --注:@s参数必须为ntext或nchar或nvarchar类型,必须将declare @s varchar(1000) 改为declare @s Nvarchar(1000) 如下: declare @s Nvarchar(1000) -- 注意此处改为nvarchar(1000) set @fname = 'FiledName' --设置字段名 set @s = 'select ' + @fname + ' from tableName' Exec(@s) -- 成功 exec sp_executesql @s -- 此句正确 3. 输入或输出参数 (1)输入参数: declare @QueryString nvarchar(1000) --动态查询语句变量(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型) declare @paramstring nvarchar(200) --设置动态语句中的参数的字符串(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型) declare @input_id int--定义需传入动态语句的参数的值 set @QueryString='select * from tablename where id=@id' --id为字段名,@id为要传入的参数 set @paramstring='@id int' --设置动态语句中参数的定义的字符串 set @input_id =1 --设置需传入动态语句的参数的值为1 exec sp_executesql @querystring,@paramstring,@id=@input_id   若有多个参数: declare @QueryString nvarchar(1000) --动态查询语句变量(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型) declare @paramstring nvarchar(200) --设置动态语句中的参数的字符串(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型) declare @input_id int--定义需传入动态语句的参数的值,参数1 declare @input_name varchar(20)--定义需传入动态语句的参数的值,参数2 set @QueryString='select * from tablename where id=@id and name=@name' --id与name为字段名,@id与@name为要传入的参数 set @paramstring='@id int,@name varchar(20)' --设置动态语句中参数的定义的字符串,多个参数用","隔开 set @input_id =1 --设置需传入动态语句的参数的值为1 set @input_name='张三' --设置需传入动态语句的参数的值为"张三" exec sp_executesql @querystring,@paramstring,@id=@input_id,@name=@input_name --请注意参数的顺序 (2)输出参数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值