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. gitlab安装备忘录

    [root@linux ~]# curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh ...

  2. CentOS源码安装Python3.6

    一.安装环境及版本 CentOS 6.5 Python 3.6.1 二.安装依赖包 1.安装静态库 # yum install -y openssl-static 注:如果不安装该静态库,会导致pyt ...

  3. 打开word时出现the setup controller has encountered a problem during install解决办法

    问题电脑为win7,office是默认安装 删除下面文件夹即可解决该问题 C:\Program Files\Common Files\Microsoft Shared\OFFICE12\Office ...

  4. Pycharm 出现Unresolved reference '' 错误的解决方法

    在用Pycharm做Pygame游戏小实战的时候碰到一个很无语的问题 如下 什么鬼?????? 我明明有写settings模块啊 而且还是放在同一个目录下  然后Pycharm给我来了一个错误 而且在 ...

  5. springMvc学习笔记一

    什么是springmvc  springmvc就是spring框架的一个模块 所以springmvc与spring之间无需通过中间整合层进行整合的. springmvc又是基于mvc的web框架 mv ...

  6. MySQL安装与使用过程中的相关问题

    数据库远程连接拒绝访问解决办法: 1. 改表法.可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql&q ...

  7. 初识Vue——计算属性和观察者

    一.计算属性 在模板内使用 1.基础例子 <template> <div class="main"> <div id="reverse_st ...

  8. Node.js的下载、安装、配置、Hello World、文档阅读

    Node.js的下载.安装.配置.Hello World.文档阅读

  9. Yii的HTML助手

    Html 帮助类 基础 表单 样式表和脚本 超链接 图片 列表 任何一个 web 应用程序会生成很多 HTMl 超文本标记.如果超文本标记是静态的, 那么将 PHP 和 HTML 混合在一个文件里 这 ...

  10. C语言_了解下结构体指针

    在C语言中几乎可以创建指向任何类型的指针,包括用户自定义的类型.当然也可以指向结构体,先看一个小案例: #include <stdio.h> #include <string.h&g ...