什么是动态SQL:动态SQL就是指根据不同的条件生成不同的SQL语句
如果你之前用过 JSTL 或任何基于类 XML 语言的文本处理器,你对动态 SQL 元素可能会感觉似曾相识。在 MyBatis 之前的版本中,需要花时间了解大量的元素。借助功能强大的基于 OGNL 的表达式,MyBatis 3 替换了之前的大部分元素,大大精简了元素种类,现在要学习的元素种类比原来的一半还要少。
- 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(30) NOT NULL COMMENT '博客作者',
`create_time` DATETIME NOT NULL COMMENT '创建时间',
`views` INT(30) NOT NULL COMMENT '浏览量'
)ENGINE=INNODB DEFAULT CHARSET=utf8
创建一个基础工程
1. 导包
2. 编写配置文件
3. 编写实体类
@Data
public class Blog {
private int id;
private String title;
private String author;
private Date createtime;
private int views;
}
4. 编写实体类对应的Mapper接口 和 Mapper.XML文件
public interface BlogMapper {
// 插入数据
int addBlog(Blog blog);
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.yang.dao.BlogMapper">
<insert id="addBlog" parameterType="blog">
insert into mybatis.blog(id,title,author,create_time,views)
values (#{id},#{title},#{author},#{createtime},#{views});
</insert>
</mapper>
5. 测试
@Test
public void addInitBlog(){
SqlSession session = MybatisUtils.getSqlSession();
BlogMapper mapper = session.getMapper(BlogMapper.class);
Blog blog = new Blog();
blog.setId(IDUtils.getId());
blog.setTitle("学好Mybatis");
blog.setAuthor("辰阳");
blog.setCreatetime(new Date());
blog.setViews(8888);
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);
session.close();
}