zoukankan      html  css  js  c++  java
  • ibatis中isEquals、isNotEmpty的用法

    一:isEquals用于动态拼接sql

    如下实例:

    如果status的状态为0,则更新attribute1;状态为1,则更新attribute2;

    状态为2,则更新attribute3。

    复制代码
    <update   id="topup.doEffect" parameterClass="java.util.HashMap">
    update  cis_customer  set  code_id  = #codeId# ,
    <isEqual property="status" compareValue="0" prepend=",">  
                attribute1=#attribute1#</isEqual>  
            <isEqual property="status" compareValue="1" prepend=",">  
                attribute2=#attribute2#</isEqual>  
            <isEqual property="status" compareValue="2" prepend=",">  
                attribute3=#attribute3#</isEqual>
    where  id = #id#
    </update>  
    复制代码

    二:isNotEmpty

    如下实例:

    查询cis_customer这张表,如果属性aaa不为空,则将条件aaa=#aaa#拼接;

    如果bbb不为空,则将条件bbb=#bbb#拼接;如果属性ccc不为空,则将条件ccc=#ccc#拼接;

    复制代码
     1 <select  id="topup.querySuccessCount" parameterClass="java.util.HashMap">
     2      select id,name from cis_customer where 1=1
     3      <isNotEmpty  property="aaa"  prepend="and">  
     4                  aaa=#aaa#
     5   </isNotEmpty  >  
     6   <isNotEmpty  property="bbb"  prepend="and">  
     7                  bbb=#bbb#
     8    </isNotEmpty  >  
     9    <isNotEmpty  property="ccc" prepend="and">  
    10                 ccc=#ccc#
    11   </isNotEmpty  >
    12   </select>  



    也可以下面这样用
    <!-- 插入一条问题来源数据 -->
    <insert id="insertWtly" parameterClass="sasbxxb" >
    insert into
    <isEqual compareValue="1" prepend=""
    property="shengfen">
    SBXX_SBBH_MUCHREG
    </isEqual>
    ( MUCHID,
    REG_NAME,
    COUNTRY,
    REG_DISTRICT,





  • 相关阅读:
    FastReport3.18使用心得
    FastReport问题整理
    SQL server 2005基于已存在的表创建分区
    SQL Server 2005对海量数据处理
    SQL SERVER2005加密解密数据
    Linux/Unix环境下的make和makefile详解 
    我想要的书
    全面提升BIND DNS服务器安全华江
    NOR和NAND Flash存储器的区别
    两个应届生找工作的好网站
  • 原文地址:https://www.cnblogs.com/zhuyeshen/p/10871420.html
Copyright © 2011-2022 走看看