MyBatis 常用写法

MyBatis 常用写法

1、forEach 循环

??forEach 元素的属性主要有 item, idnex, collection, open, separator, close。

  1. collection:传入的 List 或 Array 或自己封装的 Map。
  2. item:集合中元素迭代时的别名。
  3. idnex:集合中元素迭代是的索引。
  4. open:where 后面表示以什么开始,如以‘(’开始。
  5. separator:表示在每次进行迭代是的分隔符。
  6. close:where后面表示以什么结束,如以‘)’结束。//mapper中需要传递一个容器public List<User> queryByIdList(List<Integer> userIdList); <select id="queryByIdList" resultMap="BaseResultMap" parameterType="map"> SELECT * FROM user WHERE userId IN <foreach collection="userIdList" item="id" index="index" open="(" close=")" separator=","> #{id} </foreach> </select>

2、concat 模糊查询

//模糊查询使用concat拼接sql

<select id="queryByName" resultMap="BaseResultMap" paramterType"string"> SELECT * FROM user <where> <if test="name != null"> name like concat(‘%‘, concat(#{name}, ‘%‘)) </if> </where> </select>

3、if + where 标签

<select id="getUserList" resultMap="BaseResultMap" paramterType="com.demo.User">

SELECT * FROM user <where> <if test="userId !=null and userId!= ‘‘"> userId= #{userId} </if> <if test="name !=null and name!= ‘‘"> AND name= #{name} </if> <if phone="userId !=null and phone!= ‘‘"> AND phone= #{phone} </if> </where> </select>

where 动态语句中,where 标签会自动去掉 AND 或 OR。防止 WHERE AND 错误。

4、if + set

??使用 set 标签可以动态的配置 SET 关键字,使用 if + set 标签,如果某项为 null 则不进行更新。

<update id="updateUser" paramterType="com.demo.User"> UPDATE user <set> <iftest=" name != null and name != ‘‘"> name = #{name}, </if> <iftest=" phone != null and phone != ‘‘"> phone = #{phone}, </if> </set> WHERE userId = #{userId} </update>

5、if + trim 代替 where/set 标签

??trim 可以更灵活的去处多余关键字的标签,可以实现 where 和 set 的效果。

<select id="getUserList" resultMap="BaseResultMap" paramterType="com.demo.User"> SELECT * FROM user <trim prefix="WHERE" prefixOverrides="AND|OR"> <if test="userId !=null and userId!= ‘‘"> userId= #{userId} </if> <if test="name !=null and name!= ‘‘"> AND name= #{name} </if> <if phone="userId !=null and phone!= ‘‘"> AND phone= #{phone} </if> </trim> </select> <update id="updateUser" paramterType="com.demo.User"> UPDATE user <trim prefix="SET" suffixOverrides=","> <if test=" name != null and name != ‘‘"> name = #{name}, </if> <if test=" phone != null and phone != ‘‘"> phone = #{phone}, </if> </trim> WHERE userId = #{userId} </update>

5、choose(when, otherwise)标签

??choose 标签是按顺序判断其内部 when 标签中的 test 条件是否成立,如果有一个成立,则 choose 结束。当 choose 中所有 when 的条件都不满足,则执行 otherwise 中的 sql。类似 java 中的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。

<select id="selectCustomerByCustNameAndType" parameterType="map" resultMap="BaseResultMap"> SELECT * FROM user <choose> <when test="Utype == ‘name‘"> WHERE name = #{name} </when> <when test="Utype == ‘phone‘"> WHERE phone= #{phone} </when> <when test="Utype == ‘email‘"> WHERE email= #{email} </when> <otherwise> WHERE name = #{name} </otherwise> </choose> </select>

//mapper中需要传递一个容器public List<User> queryByIdList(List<Integer> userIdList); <select id="queryByIdList" resultMap="BaseResultMap" parameterType="map"> SELECT * FROM user WHERE userId IN <foreach collection="userIdList" item="id" index="index" open="(" close=")" separator=","> #{id} </foreach> </select>

原文地址:https://www.cnblogs.com/xiaoqianTS/p/10000393.html

时间: 2024-07-30 02:13:12

MyBatis 常用写法的相关文章

Java代码常用写法总结

1.字符串是否为空判断 以下是java 判断字符串是否为空的四种方法:方法一: 最多人使用的一个方法, 直观, 方便, 但效率很低: if(s == null ||"".equals(s));方法二: 比较字符串长度, 效率高, 是我知道的最好一个方法:                      if(s == null || s.length() <= 0);方法三: Java SE 6.0 才开始提供的方法, 效率和方法二几乎相等, 但出于兼容性考虑, 推荐使用方法二.   

【新】mybatis中大于等于小于等于的两种常用写法

mybatis中大于等于小于等于的写法 原符号 < <= > >= & ' " 替换符号 < <= > >= & &apos; " 示例sql如下: create_date_time >= #{startTime} and create_date_time <= #{endTime} 第二种写法 大于等于 <![CDATA[ >= ]]> 小于等于 <![CDATA[ <=

htaccess分布式配置文件常用写法

htaccess 写法 Apache中的.htaccess(或者”分布式配置”了针对目录改变配置的方法,即,在特定的文档目录中放置包含或多个指令的,以作用于此目录及其子目录.作为,所能的命令受到限制.***Apache的AllowOverride指令来设置. 子目录中的指令会笼盖更高级目录或者主器配置中的指令. .htaccess必需以ASCII模式上传,最好将其权限设置为644. 错误文档的定位 常用的客户端哀求错误返回代码: 401 Authorization Required 403 Fo

Spring切入点表达式常用写法

自从使用AspectJ风格切面配置,使得Spring的切面配置大大简化,但是AspectJ是另外一个开源项目,其规则表达式的语法也稍稍有些怪异. 下面给出一些常见示例的写法: 比如,下面是一个对Service包上所有方法的切面配置 <aop:config> <aop:pointcut id="serviceOperation" expression="execution(* *..service*..*(..))"/> <aop:adv

Mybatis 常用标签

MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉列名列表最后的逗号.利用动态 SQL 这一特性可以彻底摆脱这种痛苦. 1.<if> 主要用于sql语句拼接(很简单)如示例 2.<choose,when,otherwise> 有些时候,我们不想用到所有的条件语句,而只想从中择其一二.针对这种情况,MyBatis 提供了 choose

Oracle 日期各个部分常用写法

--1.日期的各部分的常用的的写法 --- --1) 取时间点的年份的写法: SELECT TO_CHAR(SYSDATE,'YYYY') FROM DUAL; --结果:2019 --2) 取时间点的月份的写法: SELECT TO_CHAR(SYSDATE,'MM') FROM DUAL; --结果:08 --3) 取时间点的日的写法: SELECT TO_CHAR(SYSDATE,'DD') FROM DUAL; --结果:01 --4) 取时间点的时的写法: SELECT TO_CHAR

Mybatis常用配置参数

Mybatis-plus官方配置详细文档:  https://mp.baomidou.com/config/常用配置参数如下: mybatis-plus: # mapper配置文件路径 mapper-locations: classpath:mybatis/mapper/*Mapper.xml # 数据库对应对象实例包 type-aliases-package: com.zsm.model configuration: #全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存,默认为 true

Mybatis常用代码

1. String conf="SqlMapConfig.xml"; Reader reader=Resources.getResourceAsReader(conf); //创建SessionFactory对象 SqlSessionFactoryBuilder sfb=new SqlSessionFactoryBuilder(); SqlSessionFactory sf=sfb.build(reader); //创建Session SqlSession session=sf.ope

mybatis常用分页插件,快速分页处理

在未分享整个查询分页的执行代码之前,先了解一下执行流程. 1.总体上是利用mybatis的插件拦截器,在sql执行之前拦截,为查询语句加上limit X X 2.用一个Page对象,贯穿整个执行流程,这个Page对象需要用java编写前端分页组件 3.用一套比较完整的三层entity,dao,service支持这个分页架构 4.这个分页用到的一些辅助类 注:分享的内容较多,这边的话我就不把需要的jar一一列举,大家使用这个分页功能的时候缺少什么就去晚上找什么jar包即可,尽可能用maven包导入