1、动态SQL片段
 通过SQL片段达到代码复用
         <!-- 动态条件分页查询 -->
         <sql id="sql_count">
                 select count(*)
         </sql>
         <sql id="sql_select">
                 select *
         </sql>
         <sql id="sql_where">
                 from icp
                 <dynamic prepend="where">
                         <isNotEmpty prepend="and" property="name">
                                 name like '%$name$%'
                         </isNotEmpty>
                         <isNotEmpty prepend="and" property="path">
                                 path like '%path$%'
                         </isNotEmpty>
                         <isNotEmpty prepend="and" property="area_id">
                                 area_id = #area_id#
                         </isNotEmpty>
                         <isNotEmpty prepend="and" property="hided">
                                 hided = #hided#
                         </isNotEmpty>
                 </dynamic>
                 <dynamic prepend="">
                         <isNotNull property="_start">
                                 <isNotNull property="_size">
                                         limit #_start#, #_size#
                                 </isNotNull>
                         </isNotNull>
                 </dynamic>
         </sql>
         <select id="findByParamsForCount" parameterClass="map" resultClass="int">
                 <include refid="sql_count"/>
                 <include refid="sql_where"/>
         </select>
         <select id="findByParams" parameterClass="map" resultMap="icp.result_base">
                 <include refid="sql_select"/>
                 <include refid="sql_where"/>
         </select>

 2、数字范围查询
 所传参数名称是捏造所得,非数据库字段,比如_img_size_ge、_img_size_lt字段
                         <isNotEmpty prepend="and" property="_img_size_ge">
                                 <![CDATA[
                                 img_size >= #_img_size_ge#
                         ]]>
                         </isNotEmpty>
                         <isNotEmpty prepend="and" property="_img_size_lt">
                                 <![CDATA[
                                 img_size < #_img_size_lt#
                         ]]>
                         </isNotEmpty> 

 多次使用一个参数也是允许的
                         <isNotEmpty prepend="and" property="_now">
                                 <![CDATA[
                                             execplantime >= #_now#
                                      ]]>
                         </isNotEmpty>
                         <isNotEmpty prepend="and" property="_now">
                                 <![CDATA[
                                             closeplantime <= #_now#
                                      ]]>
                         </isNotEmpty>

 3、时间范围查询
                         <isNotEmpty prepend="" property="_starttime">
                                 <isNotEmpty prepend="and" property="_endtime">
                                         <![CDATA[
                                         createtime >= #_starttime#
                                         and createtime < #_endtime#
                                  ]]>
                                 </isNotEmpty>
                         </isNotEmpty> 

 4、in查询
                         <isNotEmpty prepend="and" property="_in_state">
                                 state in ('$_in_state$')
                         </isNotEmpty>

 5、like查询
                         <isNotEmpty prepend="and" property="chnameone">
                                 (chnameone like '%$chnameone$%' or spellinitial like '%$chnameone$%')
                         </isNotEmpty>
                         <isNotEmpty prepend="and" property="chnametwo">
                                 chnametwo like '%$chnametwo$%'
                         </isNotEmpty> 

 6、or条件
                         <isEqual prepend="and" property="_exeable" compareValue="N">
                                 <![CDATA[
                                 (t.finished='11'    or t.failure=3)
                         ]]>
                         </isEqual>

                         <isEqual prepend="and" property="_exeable" compareValue="Y">
                                 <![CDATA[
                                 t.finished in ('10','19') and t.failure<3
                         ]]>
                         </isEqual>

 7、where子查询
                         <isNotEmpty prepend="" property="exprogramcode">
                                 <isNotEmpty prepend="" property="isRational">
                                         <isEqual prepend="and" property="isRational" compareValue="N">
                                                 code not in
                                                 (select t.contentcode
                                                 from cms_ccm_programcontent t
                                                 where t.contenttype='MZNRLX_MA'
                                                 and t.programcode = #exprogramcode#)
                                         </isEqual>
                                 </isNotEmpty>
                         </isNotEmpty>

         <select id="findByProgramcode" parameterClass="string" resultMap="cms_ccm_material.result">
                 select *
                 from cms_ccm_material
                 where code in
                 (select t.contentcode
                 from cms_ccm_programcontent t
                 where t.contenttype = 'MZNRLX_MA'
                 and programcode = #value#)
                 order by updatetime desc
         </select>

 9、函数的使用
         <!-- 添加 -->
         <insert id="insert" parameterClass="RuleMaster">
                 insert into rulemaster(
                 name,
                 createtime,
                 updatetime,
                 remark
                 ) values (
                 #name#,
                 now(),
                 now(),
                 #remark#
                 )
                 <selectKey keyProperty="id" resultClass="long">
                         select LAST_INSERT_ID()
                 </selectKey>
         </insert>
         <!-- 更新 -->
         <update id="update" parameterClass="RuleMaster">
                 update rulemaster set
                 name = #name#,
                 updatetime = now(),
                 remark = #remark#
                 where id = #id#
         </update>

 10、map结果集
         <!-- 动态条件分页查询 -->
         <sql id="sql_count">
                 select count(a.*)
         </sql>
         <sql id="sql_select">
                 select a.id                vid,
                 a.img             imgurl,
                 a.img_s         imgfile,
                 b.vfilename vfilename,
     b.name            name,
                 c.id                sid,
                 c.url             url,
                 c.filename    filename,
                 c.status        status
         </sql>
         <sql id="sql_where">
                 From secfiles c, juji b, videoinfo a
                 where
                 a.id = b. videoid
                 and b.id = c.segmentid
                 and c.status = 0
                 order by a.id asc,b.id asc,c.sortnum asc
                 <dynamic prepend="">
                         <isNotNull property="_start">
                                 <isNotNull property="_size">
                                         limit #_start#, #_size#
                                 </isNotNull>
                         </isNotNull>
                 </dynamic>
         </sql>
         <!-- 返回没有下载的记录总数 -->
         <select id="getUndownFilesForCount" parameterClass="map" resultClass="int">
                 <include refid="sql_count"/>
                 <include refid="sql_where"/>
         </select>
         <!-- 返回没有下载的记录 -->
         <select id="getUndownFiles" parameterClass="map" resultClass="java.util.HashMap">
                 <include refid="sql_select"/>
                 <include refid="sql_where"/>
         </select>

 11、trim
  trim是更灵活的去处多余关键字的标签,他可以实践where和set的效果。

  where例子的等效trim语句:
 Xml代码
 <!-- 查询学生list,like姓名,=性别 -->
 <select id="getStudentListWhere" parameterType="StudentEntity" resultMap="studentResultMap">
     SELECT * from STUDENT_TBL ST
     <trim prefix="WHERE" prefixOverrides="AND|OR">
         <if test="studentName!=null and studentName!='' ">
             ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
         </if>
         <if test="studentSex!= null and studentSex!= '' ">
             AND ST.STUDENT_SEX = #{studentSex}
         </if>
     </trim>
 </select> 

 set例子的等效trim语句:
 Xml代码
 <!-- 更新学生信息 -->
 <update id="updateStudent" parameterType="StudentEntity">
     UPDATE STUDENT_TBL
     <trim prefix="SET" suffixOverrides=",">
         <if test="studentName!=null and studentName!='' ">
             STUDENT_TBL.STUDENT_NAME = #{studentName},
         </if>
         <if test="studentSex!=null and studentSex!='' ">
             STUDENT_TBL.STUDENT_SEX = #{studentSex},
         </if>
         <if test="studentBirthday!=null ">
             STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
         </if>
         <if test="classEntity!=null and classEntity.classID!=null and classEntity.classID!='' ">
             STUDENT_TBL.CLASS_ID = #{classEntity.classID}
         </if>
     </trim>
     WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
 </update>   

 12、choose (when, otherwise)
          有时候我们并不想应用所有的条件,而只是想从多个选项中选择一个。MyBatis提供了choose 元素,按顺序判断when中的条件出否成立,如果有一个成立,则choose结束。当choose中所有when的条件都不满则时,则执行 otherwise中的sql。类似于Java 的switch 语句,choose为switch,when为case,otherwise则为default。
          if是与(and)的关系,而choose是或(or)的关系。

          例如下面例子,同样把所有可以限制的条件都写上,方面使用。选择条件顺序,when标签的从上到下的书写顺序:
 Xml代码
 <!-- 查询学生list,like姓名、或=性别、或=生日、或=班级,使用choose -->
 <select id="getStudentListChooseEntity" parameterType="StudentEntity" resultMap="studentResultMap">
     SELECT * from STUDENT_TBL ST
     <where>
         <choose>
             <when test="studentName!=null and studentName!='' ">
                     ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
             </when>
             <when test="studentSex!= null and studentSex!= '' ">
                     AND ST.STUDENT_SEX = #{studentSex}
             </when>
             <when test="studentBirthday!=null">
                 AND ST.STUDENT_BIRTHDAY = #{studentBirthday}
             </when>
             <when test="classEntity!=null and classEntity.classID !=null and classEntity.classID!='' ">
                 AND ST.CLASS_ID = #{classEntity.classID}
             </when>
             <otherwise>   

             </otherwise>
         </choose>
     </where>
 </select>  

mybatis的动态增删改查的更多相关文章

  1. MyBatis -- 对表进行增删改查(基于注解的实现)

    1.MyBatis对数据库表进行增/删/改/查 前一篇使用基于XML的方式实现对数据库的增/删/改/查 以下我们来看怎么使用注解的方式实现对数据库表的增/删/改/查 1.1  首先须要定义映射sql的 ...

  2. MyBatis简单的增删改查以及简单的分页查询实现

    MyBatis简单的增删改查以及简单的分页查询实现 <? xml version="1.0" encoding="UTF-8"? > <!DO ...

  3. Mybatis入门之增删改查

    Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...

  4. Spring Boot 使用Mybatis注解开发增删改查

    使用逆向工程是遇到的错误 错误描述 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): c ...

  5. Mybatis实现简单增删改查

    Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...

  6. SpringMVC,MyBatis商品的增删改查

    一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...

  7. 基于SSM之Mybatis接口实现增删改查(CRUD)功能

    国庆已过,要安心的学习了. SSM框架以前做过基本的了解,相比于ssh它更为优秀. 现基于JAVA应用程序用Mybatis接口简单的实现CRUD功能: 基本结构: (PS:其实这个就是用的Mapper ...

  8. mybatis中的增删改查操作

    在这一个部分,主要进行增删改查的示例书写. 增删改查可以基于xml的,也可以基于注解的方式. 一:对单条数据的查询 1.目录结构 这个使得目录更加清晰 2.User.java 这个使用以前的user表 ...

  9. ztree使用系列三(ztree与springmvc+spring+mybatis整合实现增删改查)

    在springmvc+spring+mybatis里整合ztree实现增删改查,上一篇已经写了demo,以下就仅仅贴出各层实现功能的代码: Jsp页面实现功能的js代码例如以下: <script ...

随机推荐

  1. BZOJ 2337: [HNOI2011]XOR和路径 [高斯消元 概率DP]

    2337: [HNOI2011]XOR和路径 题意:一个边权无向连通图,每次等概率走向相连的点,求1到n的边权期望异或和 这道题和之前做过的高斯消元解方程组DP的题目不一样的是要求期望异或和,期望之间 ...

  2. BZOJ 2986: Non-Squarefree Numbers [容斥原理 二分]

    题意:求第$n \le 10^{10}$个不是无平方因子数 二分答案, 容斥一下,0个质数的平方因子-1个..... 枚举$\sqrt$的平方因子乘上莫比乌斯函数,最后求出无平方因子数的个数取补集 # ...

  3. BZOJ 2822: [AHOI2012]树屋阶梯 [Catalan数 高精度]

    2822: [AHOI2012]树屋阶梯 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 779  Solved: 453[Submit][Status] ...

  4. HDU 4333 Revolving Digits [扩展KMP]【学习笔记】

    题意:给一个数字,每一次把它的最后一位拿到最前面,一直那样下去,分别求形成的数字小于,等于和大于原来数的个数. SAM乱搞失败 当然要先变SS了 然后考虑每个后缀前长为n个字符,把它跟S比较就行了 如 ...

  5. POJ 2185 Milking Grid [KMP]

    Milking Grid Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 8226   Accepted: 3549 Desc ...

  6. HibernateTemplate#setMaxResults()的坑

    如题所示,因为maxResults为实例属性,一经修改,则会应用于所有查询! 不是很清楚,Spring为什么要挖这个坑? 我的解决方案:如需设置返回结果集的大小,则通过HibernateCallbac ...

  7. ThinkPHP删除栏目(多)

    前段时间发表了一个删除栏目的随笔,当时实现的功能是删除一条信息,这次来实现一下批量删除栏目. 我们需要达到的是这样一个效果: 选中批量删除按钮后可以选中所有该页面的栏目,这个是前端页面的实现,在这里就 ...

  8. eclipse CDT unresolved inclusion

    原因:c\c++库未设置所导致的 解决办法:1.先配置环境变量:打开window->preference->c\c++bulid->environment->add-> ...

  9. Vue站点的搭建之旅

      背景       很久没写博客了,这次博客分享一下最近上班空闲时间做的两个业余Demo.分别是V电影App的移动端站点[一直很喜欢用这个APP可是他们没有出对应的mobile端,所以自己开发一个, ...

  10. Swift iOS 日期操作:NSDate、NSDateFormatter

    1.日期(NSDate) // 1.初始化 // 初始化一个当前时刻对象 var now = NSDate() // 初始化一个明天当前时刻对象 var tomorrow = NSDate(timeI ...