博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【mybatis深度历险系列】mybatis中的动态sql
阅读量:6820 次
发布时间:2019-06-26

本文共 4321 字,大约阅读时间需要 14 分钟。

最近一直做项目,博文很长时间没有更新了,今天抽空,学习了一下mybatis,并且总结一下。在前面的博文中,小编主要简单的介绍了mybatis中的输入和输出映射,并且通过demo简单的介绍了输入映射和输出映射,今天这篇博文,小编主要来简单的介绍一下mybatis中的动态sql,有的小伙伴会问,既然有动态sql,那是不是也应该存在静态sql,答案是肯定的。那么什么是静态sql呢,静态sql语句一般用于嵌入式sql应用中,在程序运行之前,sql语句必须是确定的,例如sql语句中涉及的列名和表名必须是存在的,静态sql语句的编译是在应用程序运行前进行的,编译的结果会存储在数据库内容,而后程序进行时,数据库将直接执行编译好的sql语句,降低运行时的开销。所谓的动态sql,是在应用程序运行时被编译和执行的,例如使用DB2的交互式工具CLP访问数据库时,用户输入的sql语句是不确定的,因此sql语句只能被动态的编译,动态的sql的应用较多,常见的CLI和JDBC应用程序都使用动态sql。这篇博文小编主要分三个部分来分别进行介绍,动态sql、sql片段和foreach。

一、动态sql

1.1定义

mybatis核心对sql语句进行灵活操作,通过表达式进行判断,对sql进行灵活拼接,组装。

1.2案例需求

用户信息综合查询列表这个statment的定义使用动态sql,对查询条件进行判断,如果输入参数不为空进行查询拼接。

1.3UserMapper.xml

1.4测试代码

@Test    public void testFindUserList() {        SqlSession sqlSession = sqlSessionFactory.openSession();        //创造查询条件        UserQueryVo userQueryVo = new UserQueryVo();        UserCustom userCustom = new UserCustom();//        userCustom.setSex("2");        //这里使用动态sql,如果不设置某个值,条件不会拼接sql中        userCustom.setUsername("小");        userQueryVo.setUserCustom(userCustom);        // 创建Usermapper对象,mybatis自动生成mapper代理对象        UserMapper mapper = sqlSession.getMapper(UserMapper.class);        List
list=mapper.findUserList(userQueryVo); //测试动态sql,属性的非空判断测试// List
list=mapper.findUserList(null); System.out.println(list); sqlSession.commit(); sqlSession.close(); }
二、sql片段

2.1需求

将上边的动态sql判断代码抽取出来,组成一个sql片段,其她的statment中就可以引用sql片段,方便开发。

2.2定义sql片段

and sex=#{userCustom.sex}
and username=#{userCustom.username}
2.3在mapper.xml中定义的statment中引用sql片段
三、foreach

作用:向sql传递数据或者list,mybatis使用foreach解析,在用户查询列表和查询总数的statment中增加多个id输入查询。

3.1需求:sql语句如下,两种方法:

SELECT * FROM t_user WHERE id=1 OR id=10 OR id=16

SELECT * FROM t_user WHERE id IN(1,10,16)

3.2在输入参数包装类型中添加List<Integer>ids传入多个id

package com.mybatis.entity;import java.util.List;/** *  * @ClassName: UserQueryVo * @Description: TODO(包装类型) * @author 丁国华 *  */public class UserQueryVo {    public List
ids; public List
getIds() { return ids; } public void setIds(List
ids) { this.ids = ids; }}

3.3mapper.xml代码

select *from t_user where id in(1,2,3)的mapper.xml配置

userMapper.java代码 public interface UserMapper {    //ids查询用户数据     public List
findUserByIds(UserQueryVo userQueryVo); }
Junit测试代码

@Test    public void findUserByIdsTest() {        SqlSession sqlSession = sqlSessionFactory.openSession();        // 创建Usermapper对象,mybatis自动生成mapper代理对象        UserMapper mapper = sqlSession.getMapper(UserMapper.class);        //创造查询条件        UserQueryVo userQueryVo = new UserQueryVo();        //传入多个id        List
ids=new ArrayList
(); ids.add(1); ids.add(2); ids.add(3); //将ids通过userQueryVo传入statement中 userQueryVo.setIds(ids); //调用userMapper的代码 List
userList= mapper.findUserList(userQueryVo); System.out.println(userList); sqlSession.close(); }
小编寄语:该博文小编主要简单的介绍了mybatis中的动态sql,MyBatis的一个强大的特性之一通常是它的动态 SQL 能力。如果你有使用 JDBC 或其他相似框架的经验,你就明白条件地串联 SQL字符串在一起是多么的痛苦,确保不能忘了空 格或在列表的最后省略逗号。动态 SQL可以彻底处理这种痛苦。通常使用动态SQL不可能是独立的一部分,MyBatis当然使用一种强大的动态SQL语言来改进这种情形,这种语言可以被用在任意映射的SQL语句中。

动态SQL元素和使用JSTL或其他相似的基于XML的文本处理器相似。在MyBatis之前的版本中,有很多的元素需要来了解。MyBatis3大大提升了它们,现在用不到原先一半的元素就能工作了。MyBatis采用功能强大的基于OGNL的表达式来消除其他元素。 小编博文,小编将继续介绍mybatis的相关知识,敬请期待`(*∩_∩*)′。

转载地址:http://sgpzl.baihongyu.com/

你可能感兴趣的文章