mybatis动态sql语句有哪些及使用,Mybatis动态sql有什么用-执行原理-有哪些动态sql-

  mybatis动态sql语句有哪些及使用,Mybatis动态sql有什么用?执行原理?有哪些动态sql?

  00-1010IF和WheretimHoosesetForeachMyBatis最强大的功能之一就是它的动态sql能力。

  借用官方文件:的一句话如果你之前用过JDBC或者类似的框架,你就会明白把SQL语句条件连在一起是多么痛苦的事情。确保您不会忘记空格或在列后省略逗号。动态报表完全可以解决这些痛点。

  那么如果没有这个功能有多痛苦呢?举个例子吧。

  这是一张桌子。试想一下,如果我们按姓名和年龄查询表信息,sql语句中肯定会有where和and语句。但是如果姓名或者年龄中有一个为空或者两个都为空,那么此时where和and就会被隔离,那么肯定会出现很多问题,所以mybatis的动态sql函数就完美的帮我们解决了。

  MyBatis中用于实现动态SQL的元素主要包括:

  If where修剪集选择(when,otherwise) foreach

  

目录

SELECT id= selectall Employee 1 result map= Employee map 参数Type=Employee SELECT e.id,e.name ename,e.age,d . name dname FROM Employee e LEFT JOIN dept id=d . id where if test= name!=零放大器;名字!= e . name=# { name }/if if test= age!=零放大器;年龄!= 和e.age=# {age}/if/where/select使用这个标签,动态sql可以根据条件自动帮助我们改进sql。

 

  SQL session SQL session=mybatisutil . getsql session();employee Dao mapper=SQL session . get mapper(employee Dao . class);//用设置值Employee employee=new Employee()创建一个对象;employee . set name(“”);employee.setAge(空);list employee employees=mapper . selectall employee 1(雇员);System.out.println(员工);SQL session.commit();SQL session . close();我们第一次设置null值时,表中的数据被完全查询。

  第二次,我们只询问了年龄。

  employee . set name(“”);employee . setage(20);

  查询两段20岁的数据,这就是mybatis动态sql的威力。

  00-1010以上where和if我们也可以用trim代替where。

  SELECT id= selectall Employee 1 result map= Employee map 2 parameter type= Employee SELECT e . id,e.name ename,e.age,d . name dname FROM Employee e LEFT JOIN dept id=d . id trim prefix= where prefix overrides=或and if test=name!=零放大器;名字!= e . name=# { name }/if if test= age!=零放大器;年龄!= 和e.age=#{age} /ifg

  t; </trim></select>这里有两个属性 prefix , prefixOverrides

  prefix:代表前缀 , 如果if 中有成立的条件, 就会在sql前面拼入where字句

  prefixOverrides : 根据if 条件自动判断是否去除 or and字句

  相应的也有suffix与suffixOverrides , 代表对尾部的判断

  

 

  

Choose

choose代表多路选择(多选一)

 

  

<select id="selectAllEmployee1" resultMap="employeeMap2" parameterType="Employee"> SELECT e.id,e.name ename,e.age,d.name dname FROM employee e LEFT JOIN dept d ON e.deptId = d.id <trim prefix="where" prefixOverrides="orand"> <choose> <when test="name!=null &amp; name!="> and e.name =#{name} </when> <when test="age!=null"> and e.age =#{age} </when> <otherwise> and e.name =李雷 </otherwise> </choose> </trim> </select>

当<when>中的条件成立时, 走when中的语句,都不成立走<otherwise>

 

  

 

  

Set

set 可以根据条件自动添加set字句,动态更新列,也可以来剔除追加到条件末尾的任何不相关的逗号

 

  

<update id="updateEmployee"> update employee <set> <if test="name!=null &amp; name!="> name=#{name}, </if> <if test="age!=null"> age=#{age}, </if> </set> where id=#{id} </update>

 

  

foreach

<foreach>主要用在构建 in 条件中,它可以在 SQL 语句中进行迭代一个集合。foreach元素的属性主要有 item,index,collection,open,separator,close。 item 表示集合中每一个元素进行迭代时的别名,index 指定一个名字,用于表示在迭代过程中,每次迭代到的位置,open 表示该语句以什么开始, separator 表示在每次进行迭代之间以什么符号作为分隔符,close 表示以什么结束,在使用 foreach 的时候最关键的也是最容易出错的就是 collection 属性,该属性是必须指定的,但是在不同情况下,该属性的值是不一样的。

 

  – 如果传入的是单参数且参数类型是一个 List 的时候,collection 属 性值为 list

  – 如果传入的是单参数且参数类型是一个 array 数组的时候, collection 的属性值为array

  

//创建一个list集合List<Integer> list = new ArrayList<>();list.add(19);list.add(20);List<Employee> employees = mapper.selectAllEmployee2(list);

接口方法如下 :

 

  

 List<Employee> selectAllEmployee2(List<Integer> list);

对应动态sql如下 :

 

  

<select id="selectAllEmployee2" resultMap="employeeMap2" parameterType="Employee"> SELECT e.id,e.name ename,e.age,d.name dname FROM employee e LEFT JOIN dept d ON e.deptId = d.id where age in <foreach collection="list" item="age" open="(" separator="," close=")"> #{age} </foreach> </select>

这里我们传入的是一个集合, 所以参数选择 list , 通过foreach我们可以动态的根据集合里的值来查询

 

  关于动态sql就介绍到这,感谢阅读 !

  到此这篇关于MyBatis深入解读动态SQL的实现的文章就介绍到这了,更多相关MyBatis动态SQL内容请搜索盛行IT以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT!

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: