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. 浅谈JavaScript的事件(事件类型)

    Web浏览器能够发生的事件有很多种类型,不同的事件类型有不同的事件信息.DOM3级的事件类型主要包括:UI事件,用户与页面上的元素交互时触发:焦点事件,元素获得或失去焦点触发:鼠标事件,用户通过鼠标在 ...

  2. 在window上安装redis

    redis没有官方的windows版本,如果需要在windows安装可以下载由微软维护的redis(https://github.com/MicrosoftArchive/redis). 在这里我们采 ...

  3. Windows Server 2016-重命名域控制器

    当公司发展到一定规模或者信息化建设到一定程度的情况下,很多信息化规范出台:很多初期服务器搭建包括服务搭建等计算机名等都是按照默认或者随机命名的,不便于区分业务或服务等.通过前边的章节我们对Active ...

  4. CentOS安装EPEL Remi

    EPEL,Remi 因为Centos官方源很多软件都没有,编译安装又比较麻烦,可以安装EPEL源Remi源解决此问题. CentOS 5.x : wget http://dl.fedoraprojec ...

  5. WPF ----在UserControl的xaml里绑定依赖属性

    场景:在定义wpf 用户控件的时候,希望使用时设置自定义的属性来改变用户控件里的状态或内容等. 下面直接上实例代码: 用户控件的后台代码,定义依赖属性 public partial class MyU ...

  6. console那些你不曾知道的玩法

    一.console最常见的四种方法: FireFox(58) Chrome(51) 二.打印对象: 平时想输出对象属性时,可以直接打印对象,对Object使用toString方法会得到 [Object ...

  7. centos7安装部署gitlab服务器

    [gitlab需要内存至少4GB]   我这里使用的是centos 7 64bit,我试过centos 6也是可以的! 1. 安装依赖软件 yum -y install policycoreutils ...

  8. 用UltraISO制作CentOS U盘安装盘

    1    下载UltraISO 网上有很多版本,下个绿色版的就ok了. 下载地址:http://www.pc6.com//softview/SoftView_13698.html 2    下载Cen ...

  9. linux scp远程拷贝文件及文件夹

    [http://www.jb51.net/LINUXjishu/73131.html] 1.拷贝本机/home/administrator/test整个目录至远程主机192.168.1.100的/ro ...

  10. C++11 标准库也有坑(time-chrono)

    恰巧今天调试程序遇到时间戳问题, 于是又搜了搜关于取时间戳,以及时间戳转字符串的问题, 因为 time()   只能取到秒(win和linux) 想试试看能不能找到 至少可以取到毫秒的, 于是, 就找 ...