转:http://www.cnblogs.com/lixiujie/p/5766669.html
<resultMap>标签的使用:这个类似于hibernte用于映射我们创建的vo对象与数据库字段的对应。
关于具体的使用参考此博文:
http://blog.csdn.net/bear_wr/article/details/52383840
mybatis where标签的使用
where后面跟查询条件 简化sql语句中判断条件的书写
例:
<select >
and gender=#{gender}
</if>
</where>
</select>
MyBatis会智能的把首个and 或 or 给忽略
如果id为null 执行的sql语句为 :
select * from user where name='xxx' and gender='xxx'
mybatis set标签的使用
例:
<update >
gender=#{gender},
</if>
</set>
</update>
如上片段假如都不为null的情况下执行SQL为: update user set ,name='xxx',gender='xxx';
在如上sql中最后一个逗号会被set标记自动忽略不计
mybatis trim标签的使用
trim 属性
prefix:前缀
suffix:后缀
prefixOverrides:忽略第一个指定分隔符
suffixOverrides:会略最后一个分隔符
例:
1)
<select >
and gender=#{gender}
</if>
</trim>
</select>
如果id为null执行的sql语句为:
select * from user where name="xxx" and gender="xxx"
2)
<update>
update user
<trim prefix="set" suffixoverride=",">
<if test="id!=null and id!=''">
id=#{id},
</if>
<if test="name!=null and name!=''">
name=#{name},
</if>
<if test="gender!=null and gender!=''">
gender=#{gender}
</if>
</trim>
</update>
如果gender为null 执行的sql语句为:
update user set
mybatis foreach标签的使用
可以利用<foreach>标签实现sql条件的循环,可完成类似批量的sql
mybatis接受的参数分为:
(1)基本类型(2)对象(3)List(4)数组(5)Map
参数:
collection:要循环的集合
index:定一个名字,用于表示在迭代过程中,每次迭代到的位置
item:集合中每一个元素进行迭代时的别名
open:以什么开始
close:以什么结束
separator:循环内容之间以什么分隔
例:
1)批量添加
<insert >
#{id}
</foreach>
</delete>
如果有两条数据要删除 执行的sql语句为:
delete from user where id in(1,2)
mybatis sql标签的使用
通过sql片段达到代码重复利用
例:
<sql >
from user
</sql>
<select />
</select>
转:http://www.cnblogs.com/lixiujie/p/5766669.html
<resultMap>标签的使用:这个类似于hibernte用于映射我们创建的vo对象与数据库字段的对应。
关于具体的使用参考此博文:
http://blog.csdn.net/bear_wr/article/details/52383840
mybatis where标签的使用
where后面跟查询条件 简化sql语句中判断条件的书写
例:
<select >
and gender=#{gender}
</if>
</where>
</select>
MyBatis会智能的把首个and 或 or 给忽略
如果id为null 执行的sql语句为 :
select * from user where name='xxx' and gender='xxx'
mybatis set标签的使用
例:
<update >
gender=#{gender},
</if>
</set>
</update>
如上片段假如都不为null的情况下执行SQL为: update user set ,name='xxx',gender='xxx';
在如上sql中最后一个逗号会被set标记自动忽略不计
mybatis trim标签的使用
trim 属性
prefix:前缀
suffix:后缀
prefixOverrides:忽略第一个指定分隔符
suffixOverrides:会略最后一个分隔符
例:
1)
<select >
and gender=#{gender}
</if>
</trim>
</select>
如果id为null执行的sql语句为:
select * from user where name="xxx" and gender="xxx"
2)
<update>
update user
<trim prefix="set" suffixoverride=",">
<if test="id!=null and id!=''">
id=#{id},
</if>
<if test="name!=null and name!=''">
name=#{name},
</if>
<if test="gender!=null and gender!=''">
gender=#{gender}
</if>
</trim>
</update>
如果gender为null 执行的sql语句为:
update user set
mybatis foreach标签的使用
可以利用<foreach>标签实现sql条件的循环,可完成类似批量的sql
mybatis接受的参数分为:
(1)基本类型(2)对象(3)List(4)数组(5)Map
参数:
collection:要循环的集合
index:定一个名字,用于表示在迭代过程中,每次迭代到的位置
item:集合中每一个元素进行迭代时的别名
open:以什么开始
close:以什么结束
separator:循环内容之间以什么分隔
例:
1)批量添加
<insert >
#{id}
</foreach>
</delete>
如果有两条数据要删除 执行的sql语句为:
delete from user where id in(1,2)
mybatis sql标签的使用
通过sql片段达到代码重复利用
例:
<sql >
from user
</sql>
<select />
</select>