动态SQL
什么是动态SQL:动态SQL就是指根据不同的条件生成不同的SQL语句
动态SQL的元素标签:
if
choose (when, otherwise)
trim (where, set)
foreach
搭建环境
SQL建表
CREATE TABLE `blog`(
`id` varchar(50) NOT NULL COMMENT '博客id',
`title` varchar(100) NOT NULL COMMENT '博客标题',
`author` varchar(30) NOT NULL COMMENT '博客作者',
`CREATE_time` datetime NOT NULL COMMENT '创建时间',
`views` int(30) NOT NULL COMMENT '浏览量',
)ENGINE=InnoDB DEFAULT CHARSET=utf8
创建工程
1.导包
2.编写配置文件
3.编写实体类
4.编写实体类对应的 Mapper接口List<Blog> queryBlogIF(Map map);
和 Mapper.xml文件
IF
<select id="queryBlogIF" parameterType="map" resultType="blog">
select * from blog
<where>
<if test="title!=null">
and title=#{title}
</if>
<if test="author!=null">
and author=#{author}
</if>
</where>
</select>
choose (when, otherwise)
<select id="queryBlogChoose" resultType="blog" parameterType="map">
select * from blog
<where><!--只有一条语句会执行-->
<choose>
<when test="title!=null">
and title=#{title}
</when>
<when test="author!=null">
and author=#{author}
</when>
<otherwise>
and views=#{views}
</otherwise>
</choose>
</where>
</select>
trim (where, set)
<where></where> where标签相当于where 1=1 ,嵌套在if标签外面。
<update id="updateBlog" parameterType="map">
update blog
<set>
<if test="title!=null">
title=#{title},
</if>
<if test="author!=null">
author=#{author},
</if>
</set>
where id=#{id}
</update>
mybatis的trim标签一般用于去除sql语句中多余的and关键字,逗号,或者给sql语句前拼接 “where“、“set“以及“values(“ 等前缀,或者添加“)“等后缀,可用于选择性插入、更新、删除或者条件查询等操作。
所谓动态SQL,本质还是SQL语句,只是我们可以在SQL层面去执行一些逻辑代码
SQL片段
有的时候,我们可能将一些功能的部分抽取出来,方便复用
1.sql抽取
<sql id="if-title-author">
<if test="title!=null">
and title=#{title}
</if>
<if test="author!=null">
and author=#{author}
</if>
</sql>
2.在需要使用的地方使用include标签引用
<select id="queryBlogIF" parameterType="map" resultType="blog">
select * from blog
<where>
<include refid="if-title-author"></include>
</where>
</select>
注意事项:
- 最好基于单表定义SQL片段
- sql片段不要存在where标签
Foreach
1、编写xml sql语句
select * from user where 1=1 and (id=1 or id=2 or id=3)
使用foreach---->
<select id="queryBlogForeach" parameterType="map" resultType="blog">
select * from blog
<where>
<foreach collection="ids" item="id" open="and (" close=")" separator="or">
id=#{id}
</foreach>
</where>
</select>
2.测试
@Test
public void queryBlogForeach(){
SqlSession sqlSession = MybaitsUtils.getSqlSession();
BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
Map map=new HashMap();
ArrayList<Integer> ids = new ArrayList<Integer>();
ids.add(1);
ids.add(2);
map.put("ids",ids);
List<Blog> blogs = mapper.queryBlogForeach(map);
for (Blog blog : blogs) {
System.out.println(blog);
}
sqlSession.close();
}
3.结果
动态SQL就是在拼接SQL语句,我们只要保证SQL的正确性,按照SQL的格式,去排列组合就可以了
建议:
- 先在Mysql中写出完整的SQL,再对应的去修改称为我们的动态SQL实现调用