zoukankan      html  css  js  c++  java
  • ibatis动态查询条件

    ibatis的调试相对困难,出错的时候主要依据是log4生成的log文件和出错提示,这方面要能比较熟练的看懂.

    下面这个配置基本上包含了最复杂的功能:分页\搜索\排序\缓存\传值Hash表\返回hash表\动态sql

    如果对下面这段配置能信手粘来的话,那开发速度将会大大的提升.

    <statement id="XinxiTable_SelectAll" listClass="ArrayList"
                   resultMap="SimpleXinxi" parameterClass="Hashtable" cacheModel="xinxi-cache" >
          SELECT
            <dynamic prepend="top">
              <isNotEqual prepend="top" property="TopNum" compareValue = "0">
                $TopNum$
              </isNotEqual>
            </dynamic>
          *
          FROM
          (select a.[iXinxiID],a.[sXinxiTitle],a.[iXinxiClassId],b.[sClassName],
          a.[dXinxiDate],a.[dXinxiYxq],a.[iXinxiHits],a.[sXinxiUser],a.[sRedirectUrl],
          ROW_NUMBER() OVER(
          <dynamic prepend="order by">
          <isEqual prepend="order by" property="Sort" compareValue = "0">
            a.iXinxiID desc
          </isEqual>
          <isEqual prepend="order by" property="Sort" compareValue = "1">
            a.iXinxiID asc
          </isEqual>
          <isEqual prepend="order by" property="Sort" compareValue = "2">
            a.iXinxiHits desc
          </isEqual>
          <isEqual prepend="order by" property="Sort" compareValue = "3">
            a.iXinxiHits asc
          </isEqual>
        </dynamic>
          ) as row
          FROM
          [dbo].[XinxiTable] as a,[dbo].[XinxiClass] as b
          <dynamic prepend="where">
            <isParameterPresent>
              <isNotEmpty prepend="and" property="XinxiType" >
                a.[iXinxiState]= $XinxiType$
              </isNotEmpty>
              <isNotEqual prepend="and" property="XinxiClass" compareValue = "0">
                a.[iXinxiClassID]= $XinxiClass$
              </isNotEqual>
              <isEqual prepend="and" property="SearchType" compareValue = "1">
                a.[sXinxiTitle] LIKE '%$Keyword$%'
              </isEqual>
              <isEqual prepend="and" property="SearchType" compareValue = "2">
                (a.[sXinxiTitle] LIKE '%$Keyword$%' or a.[sXinxiContent] LIKE '%$Keyword$%')
              </isEqual>
            </isParameterPresent>
          </dynamic>
          and a.iXinxiClassId=b.iClassId
          )a
          <dynamic prepend="where">
            <isParameterPresent>
              <isEqual prepend="and" property="IsPage" compareValue = "1">
                row between $PageLower$ and $PageUpper$
              </isEqual>
            </isParameterPresent>
          </dynamic>
        </statement>

    ibatis动态查询条件:

    <select id="SelectEemployee" parameterClass="string" resultMap = "employee-result">

                select * from employee

    //动态SQL语句

                 <dynamic prepend="WHERE">

                     <isParameterPresent>

                           emp_id = #value#

                     </isParameterPresent>

                  </dynamic>

            </select>

        </statements>

    </sqlMap>

    /*

    动态SQL的写法:

    开始 <dynamic

    条件成立时前面要加的字符串 prepend ="字符串">

    <属性关键字  (见下表)

    prepend="字符串"

    判断条件的对象属性名 property="字符串"

    如果是属性关键字是比较条件时,字符串存放要比较的值compareValue="字符串">

    要显示的条件名

    </属性关键字>

    结束</dynamic>

    */

    /*

    动态SQL的参数有

    属性关键字

    含义

    <isEqual>

    如果参数相等于值则查询条件有效。

    <isNotEqual>

    如果参数不等于值则查询条件有效。

    <isGreaterThan>

    如果参数大于值则查询条件有效。

    <isGreaterEqual>

    如果参数等于值则查询条件有效。

    <isLessEqual>

    如果参数小于值则查询条件有效。如下所示:

    <isLessEqual prepend = ”AND” property = ”age” compareValue = ”18” >

    ADOLESCENT = ‘TRUE’

    </isLessEqual>

    <isPropertyAvailable>

    如果参数有使用则查询条件有效。

    <isNotPropertyAvailable>

    如果参数没有使用则查询条件有效。

    <isNull>

    如果参数为NULL则查询条件有效。

    <isNotNull>

    如果参数不为NULL则查询条件有效。

    <isEmpty>

    如果参数为空则查询条件有效。

    <isNotEmpty>

    如果参数不为空则查询条件有效。参数的数据类型为Collection、String 时参数不为NULL或“”。如下所示:

    <isNotEmpty prepend=”AND” property=”firstName” >

    FIRST_NAME=#firstName#

    </isNotEmpty>

    <isParameterPresent>

    如果参数类不为NULL则查询条件有效。

    <isNotParameterPresent>

    Checks to see if the parameter object is not present (null). Example Usage:

    <isNotParameterPresent prepend=”AND”>

    EMPLOYEE_TYPE = ‘DEFAULT’

    </isNotParameterPresent>

     

    ibatis如何出入动态传入指定表和指定列查询对应数据?

    ibatis 的配置如下:

    <select id="selectDataOfTable" resultClass="java.util.Hashtable" parameterClass="java.util.Map">

        <![CDATA[

        SELECT $column$ FROM $tableName$

        ]]>

        </select>

    当传出:tableName: CC_RPT_DF01

    column   :

    TO_CHAR(MONTH_CODE,'yyyy-MM-dd hh:mi:ss') MONTH_CODE,decode(BUSINESS_PLACE_CODE,NULL,'',BUSINESS_PLACE_CODE)BUSINESS_PLACE_CODE,decode(PRICE_ID,NULL,'',PRICE_ID)PRICE_ID,decode(TRADE_CODE,NULL,'',TRADE_CODE)TRADE_CODE,decode(INTERVAL,NULL,'',INTERVAL)INTERVAL,decode(TOTAL_POWER,NULL,0,TOTAL_POWER)TOTAL_POWER,decode(TOTAL_POWER_YG,NULL,0,TOTAL_POWER_YG)TOTAL_POWER_YG,decode(TOTAL_POWER_WG,NULL,0,TOTAL_POWER_WG)TOTAL_POWER_WG,decode(FAVOR_POWER,NULL,0,FAVOR_POWER)FAVOR_POWER,decode(ADD_POWER,NULL,0,ADD_POWER)ADD_POWER,decode(TOTAL_FEE,NULL,0,TOTAL_FEE)TOTAL_FEE,decode(CONTENT_FEE,NULL,0,CONTENT_FEE)CONTENT_FEE,decode(CAPA,NULL,0,CAPA)CAPA,decode(CAPA_FEE,NULL,0,CAPA_FEE)CAPA_FEE,decode(NEED,NULL,0,NEED)NEED,decode(NEED_FEE,NULL,0,NEED_FEE)NEED_FEE,decode(BASE_FEE,NULL,0,BASE_FEE)BASE_FEE,decode(COS_ADD_FEE,NULL,0,COS_ADD_FEE)COS_ADD_FEE,decode(COS_REDUCE_FEE,NULL,0,COS_REDUCE_FEE)COS_REDUCE_FEE,decode(FAVOR_FEE,NULL,0,FAVOR_FEE)FAVOR_FEE,decode(ADD_FEE,NULL,0,ADD_FEE)ADD_FEE,decode(SANXIA_FEE,NULL,0,SANXIA_FEE)SANXIA_FEE,decode(CHENGSHI_FEE,NULL,0,CHENGSHI_FEE)CHENGSHI_FEE,decode(PROVINCE_FEE,NULL,0,PROVINCE_FEE)PROVINCE_FEE,decode(STATE_FEE,NULL,0,STATE_FEE)STATE_FEE,decode(NONGWANG_FEE,NULL,0,NONGWANG_FEE)NONGWANG_FEE,decode(ENERGY_FEE,NULL,0,ENERGY_FEE)ENERGY_FEE,decode(OTHER_FEE,NULL,0,OTHER_FEE)OTHER_FEE,decode(USER_COUNT,NULL,0,USER_COUNT)USER_COUNT

    能查出CC_RPT_DF01 表对应 列  的数据 。

    当第二次传入  tableName:CC_RPT_DF11

    column   :

    TO_CHAR(MONTH_CODE,'yyyy-MM-dd hh:mi:ss') MONTH_CODE,decode(BUSINESS_PLACE_CODE,NULL,'',BUSINESS_PLACE_CODE)BUSINESS_PLACE_CODE,decode(VOLTAGE_LEVEL,NULL,'',VOLTAGE_LEVEL)VOLTAGE_LEVEL,decode(SALE_ID,NULL,'',SALE_ID)SALE_ID,decode(USER_NUM,NULL,0,USER_NUM)USER_NUM,decode(SUM_CAPA,NULL,0,SUM_CAPA)SUM_CAPA

    Check the selectDataOfTable-AutoResultMap. 

    --- Check the result mapping for the 'PRICE_ID' property. 

    --- Cause: java.sql.SQLException: 列名无效; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:  

    --- The error occurred in com/szp/eai/dataobject/Common.xml. 

    --- The error occurred while applying a result map. 

    第二次传入的列名和数据库表中一致。

    我感觉好像 SELECT $column$ FROM $tableName$ 这中语句,ibatis记住了第一次出入的列,第二次传入的新列没有用。

    要实现这中功能,ibatis该如何做?

    答案:

    这个问题是因为你查询的sql的列是变化的,但是ibatis默认的会缓存RS中的meta信息,如果你第一次查询的列和第二次查询的列不一样的话,那么第二次ibatis还会以第一次查询的列为key从RS里面获取数据,但是你的列是变化的,所以第二次取数据的时候,RS里面已经没有了你第一次的那个列了,所以会出错。 幸好ibatis 可以设置来改变这种缓存引起的问题,就是这个remapResults=true

    <select id="" parameterClass="" resultClass="" remapResults="true">

    </select>

    iBATISselect 标签 # $区别------模糊查询

       在IbatiS的select中有两个占位符 # 和 $

       我们先看一个 一个查询语句:

        select * from user where Name = #userName#;

       我们用#这个占位符可以查询到 我们想要的结果,可是当我们需要模糊查询的时候该怎么办呢?

       select * from user where Name = ‘%#userName#%’(错误的写法);如果我们这样写,程序在编译的时候会报错,因为 # 这个占位符前面还有别的 符号,#这个占位符是不允许这样写的,这个时候我们就可以用 $ 这个占位符:

       select * from user where Name = ‘%$userName$%’(正确的模糊查询写法),这样写编译器不会报错,也能得到我们想要的结果。

        归根结底的原因就是 # 占位符会把我们的SQL 语句翻译成

        select * from user where Name = ? 这样的语句,然后在填充参数。

        $ 占位符会把我们的SQL语句 翻译成

        select * from user where Name = '想要查询的东西' 这个样标准的SQL语句

  • 相关阅读:
    《Orange‘s》 Bochs环境配置
    《CSAPP》读书笔记
    基于SDL2实现俄罗斯方块
    VS 提示对象被多次指定;已忽略多余的指定
    SDL2.0 vs2017环境配置
    初探模板元编程
    从代码理解 cartographer X --- 浅析Cartographer框架之美
    从代码理解 cartographer 1
    Arch Linux 安装总结
    从代码理解 cartographer 3 --- 理解 Range data 数据的流入
  • 原文地址:https://www.cnblogs.com/langtianya/p/2969557.html
Copyright © 2011-2022 走看看