什么是动态SQL:动态SQL就是指根据不同的条件生成不同的SQL语句
利用动态SQL这一特性可以彻底摆脱这种痛苦
动态SQL元素和JSTL或基于类似XML的文本处理器相似。在MyBatis之前的版本中,有很多元素需要花时间了解。MyBatis 3大大精简了元素种类,现在只需学习原来一半的元素便可。MyBatis采用功能强大的基于OGNL的表达式来淘汰其它大部分元素。
- if
- choose (when, otherwise)
- trim (where, set)
- foreach
CREATE TABLE `blog`( `id` VARCHAR(50) NOT NULL COMMENT '博客id', `title` VARCHAR(100) NOT NULL COMMENT '博客标题', `author` VARCHAR(100) NOT NULL COMMENT '博客作者', `create_time` DATETIME NOT NULL COMMENT '创建时间', `views` INT(30) NOT NULL COMMENT '浏览量' )ENGINE=INNODB DEFAULT CHARSET=utf8
1、创建一个基础maven子工程mybatis-08
2、导入Lombok包
3、编写配置文件(拷贝前面的配置文件和工具类)
4、编写实体类
@Data
public class Blog {
private String id;
private String title;
private String author;
private Date createTime;//属性名和字段名不一致
private int views;
}
5、工具类设置添加ID为随机
@SuppressWarnings("all")//抑制警告
public class IDutils {
public static String getId() {
return UUID.randomUUID().toString().replaceAll("-","");
}
@Test
public void test(){
System.out.println(IDutils.getId());
System.out.println(IDutils.getId());
System.out.println(IDutils.getId());
}
6、开启驼峰命名自动映射
7、测试添加数据
insert into mybatis.blog(id,title,author,create_time,views) values (#{id},#{title},#{author},#{createTime},#{views});
@Test
public void test() {
// System.out.println(IDutils.getId());
SqlSession sqlSession = MybatisUtils.getSqlSession();
BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
Blog blog = new Blog();
blog.setId(IDutils.getId());
blog.setTitle("Mybatis");
blog.setAuthor("神");
blog.setCreateTime(new Date());
blog.setViews(9999);
mapper.addBlog(blog);
blog.setId(IDutils.getId());
blog.setTitle("Java");
mapper.addBlog(blog);
blog.setId(IDutils.getId());
blog.setTitle("Spring");
mapper.addBlog(blog);
blog.setId(IDutils.getId());
blog.setTitle("微服务");
mapper.addBlog(blog);
sqlSession.close();
}
8、编写实体类对应Mapper接口和Mapper.XML文件
1、IFpublic interface BlogMapper {
//插入数据
int addBlog(Blog blog);
//查询博客
List queryBlogIF(Map map);
}
测试查询
@Test
public void testqueryBlogIF() {
SqlSession sqlSession = MybatisUtils.getSqlSession();
BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
HashMap hashMap = new HashMap();
hashMap.put("title","Mybatis");
List blogs = mapper.queryBlogIF(hashMap);
for (Blog blog : blogs) {
System.out.println(blog);
}
sqlSession.close();
}
2、choose (when, otherwise)
3、trim (where,set)
select * from blog
and title =#{title}
and author =#{author}
update blog where id=#{id} title =#{title}, author =#{author}
所谓的动态SQL,本质还是SQL语句,只是我们可以在SQL层面,去执行一个逻辑代码
SQL片段有的时候,我们可能会将一些公共的部分抽取出来,方便复用!
1、使用SQL标签抽取公共的部分
title =#{title} author =#{author}
2、在需要使用的地方使用Include标签引用即可
注意事项:
-
最好基于单表来定义SQL片段!
-
不要存在where标签
select * from blog where 1=1 and#{id} (id=1 or id =2 or id=3)
@Test
public void testqueryBlogForeach(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
HashMap hashMap = new HashMap();
ArrayList ids = new ArrayList();
ids.add(1);
ids.add(2);
hashMap.put("ids",ids);
List blogs = mapper.queryBlogForeach(hashMap);
for (Blog blog : blogs) {
System.out.println(blog);
}
sqlSession.close();
}
select * from blog
id=#{id}
动态SQL就是在拼接SQL语句,我们只要保证SQL的正确性,按照SQL的格式,去排列组合就可以了
建议:
现在Mysql中写出完整的SQL,再对应的去修改成为我们的动态SQL实现通用即可!



