动态SQL介绍以及环境搭建

简介: 动态SQL介绍以及环境搭建

动态SQL介绍


动态SQL指的是根据不同的查询条件,生成不同的sql语句


官网描述: MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其它类似框架的经验,你 就能体会到根据不同条件拼接 SQL 语句的痛苦。例如拼接时要确保不能忘记添加必要的空格,还要注意 去掉列表最后一个列名的逗号。利用动态 SQL 这一特性可以彻底摆脱这种痛苦。 虽然在以前使用动态 SQL 并非一件易事,但正是 MyBatis 提供了可以被用在任意 SQL 映射语 句中的强大的动态 SQL 语言得以改进这种情形。 动态 SQL 元素和 JSTL 或基于类似 XML 的文本处理器相似。在 MyBatis 之前的版本中,有 很多元素需要花时间了解。MyBatis 3 大大精简了元素种类,现在只需学习原来一半的元素便可。 MyBatis 采用功能强大的基于 OGNL 的表达式来淘汰其它大部分元素。 ------------------------------ - if - - choose (when, otherwise) - - trim (where, set) - - foreach ------------------------------


我们之前写的SQL语句都比较简单,如果有比较复杂的业务我们需要写复杂的SQL语句,往往需要拼接,而拼接sql,稍微不注意,由于引号,空格等缺失可能都会导致错误


这就要使用 mybatis 动态SQL,通过 if, choose, when, otherwise, trim, where, set, foreach等标签,可组合成非常灵活的SQL语句,从而在提高 SQL 语句的准确性的同 时,也大大提高了开发人员的效率。


搭建环境


新建一个数据库表:bigo

字段:id,title,author,create_time,views

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.创建MyBatis基础工程

20200819214520656.png


2.IDutil工具类

为了生成序列码

public class IDUtil {
    public static String genId(){        
    return UUID.randomUUID().toString().replaceAll("-","");    
    }
}


3.实体类编写【注意set方法作用】

import java.util.Date;
public class Blog {
   private String id;    
   private String title;   
   private String author;   
   private Date createTime;    
   private int views;    
   //set,get.... 
 }


4.编写Mapper接口及xml文件

public interface BligMapper{
}
<?xml version="1.0" encoding="UTF-8" ?> 
<!DOCTYPE mapper        
      PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"        
      "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="com.kuang.mapper.BlogMapper">
</mapper>


5.mtbatis核心配置文件,下划线驼峰自动转换

<settings>    
  <setting name="mapUnderscoreToCamelCase" value="true"/>    
  <setting name="logImpl" value="STDOUT_LOGGING"/> 
</settings> 
<!--注册Mapper.xml--> 
<mappers>  
  <mapper resource="mapper/BlogMapper.xml"/> 
</mappers>


6.插入初始化数据

编写接口

int addBiog(Biog blog);


sql配置文件

<insert id="addBlog" parameterType="blog">    
insert into blog (id, title, author, create_time, views)    
values (#{id},#{title},#{author},#{createTime},#{views}); 
</insert>


初始化博客方法

@Test public void addInitBlog(){    SqlSession session = MybatisUtils.getSession();    
BlogMapper mapper = session.getMapper(BlogMapper.class);
    Blog blog = new Blog();    
    blog.setId(IDUtil.genId());    
    blog.setTitle("Mybatis如此简单");    
    blog.setAuthor("狂神说");    
    blog.setCreateTime(new Date());    
    blog.setViews(9999);
    mapper.addBlog(blog);
    blog.setId(IDUtil.genId());    
    blog.setTitle("Java如此简单");   
     mapper.addBlog(blog);
    blog.setId(IDUtil.genId());    
    blog.setTitle("Spring如此简单");   
    mapper.addBlog(blog);
    blog.setId(IDUtil.genId());    
    blog.setTitle("微服务如此简单");    
    mapper.addBlog(blog);
    session.close(); }
相关文章
|
5月前
|
SQL Java 编译器
SQL 语言:嵌入式 SQL 和动态 SQL
SQL 语言:嵌入式 SQL 和动态 SQL
73 4
|
6月前
|
SQL Java 关系型数据库
Mybatis多表关联查询与动态SQL(下)
Mybatis多表关联查询与动态SQL
124 0
|
6月前
|
SQL Java 数据库连接
Mybatis多表关联查询与动态SQL(上)
Mybatis多表关联查询与动态SQL
181 0
|
4月前
|
SQL Java 数据库连接
mybatis动态SQL常用语法总结
MyBatis 使用 OGNL 表达式语言处理动态SQL,如 `if` 标签进行条件判断,`choose`、`when`、`otherwise` 实现多条件选择,`where`、`set` 管理SQL关键字,`trim` 提供通用修剪功能,`foreach` 遍历集合数据。`sql` 和 `include` 用于代码重用,`selectKey` 处理插入后的返回值。参数传递支持匿名、具名、列表、Map、Java Bean和JSON方式。注意SQL转义及使用合适的jdbcType映射Java类型。
86 7
|
5月前
|
SQL XML 数据库
后端数据库开发高级之通过在xml文件中映射实现动态SQL
后端数据库开发高级之通过在xml文件中映射实现动态SQL
50 3
|
5月前
|
SQL XML Java
MyBatis第四课动态SQL
MyBatis第四课动态SQL
|
5月前
|
SQL XML Java
Mybatis进阶——动态SQL(1)
Mybatis进阶——动态SQL(1)
40 3
|
5月前
|
SQL 存储 关系型数据库
17. Mysql 动态SQL
17. Mysql 动态SQL
87 1
|
5月前
|
SQL 缓存 Java
Java框架之MyBatis 07-动态SQL-缓存机制-逆向工程-分页插件
Java框架之MyBatis 07-动态SQL-缓存机制-逆向工程-分页插件
|
5月前
|
SQL Java 数据库连接
MyBatis动态SQL
MyBatis动态SQL
59 0