ibatis 動態列緩衝問題;oracle行轉列;oracle使用數字或特殊字元作列的別名

來源:互聯網
上載者:User

1、iBatis會自動緩衝每條查詢語句的列名映射,所有如果你動態產生列名的話就有可能造成查詢列名無效的問題。

ibaits 會緩衝查詢的meta資訊,在產生動態列時一定要加上
remapResults="true"。

2、oracle查詢sql中,想使用數字或特殊字元作列的別名時,可以用“”引起來。

3、oracle行轉列,事先需要確定查詢的列資訊,在列用sum和decode函數匯總

如:



<select id="queryZjhHzByRq" parameterClass="com.athena.paicjh.entity.paiczjhjs.Paiczjhjs" resultClass="java.util.HashMap" remapResults="true">select zcwlh || '(' || sum(sl) || ')' zcwlh<iterate property="beanList"> ,sum(decode(rksj, #beanList[].rksj#, sl, 0)) "$beanList[].rksj$" </iterate>  from (select to_char(jz.rksj, 'yyyy-mm-dd') rksj,               jz.zcwlh,               sum(nvl(jz.sl, 0)) sl,               jz.ptbz          from jh_zjh jz         where jz.usercenter = #usercenter#           and jz.rksj >= to_date(#start#, 'yyyy-mm-dd')           and jz.rksj <![CDATA[<=]]> to_date(#end#, 'yyyy-mm-dd')           <isNotEmpty prepend="and" property="zcwlh">zcwlh like $zcwlh$</isNotEmpty>         group by jz.rksj, jz.zcwlh, jz.ptbz        union all        select to_char(to_date(rksj, 'yyyymm'), 'yyyy-mm') rksj,               zcwlh,               sum(nvl(sl, 0)) sl,               '2' ptbz          from jh_yzjh         where usercenter = #usercenter#           and drbz = '0'           and to_date(rksj || '01', 'yyyymmdd') >= to_date(#start#, 'yyyy-mm-dd')           and to_date(rksj || '01', 'yyyymmdd') <![CDATA[<=]]> to_date(#end#, 'yyyy-mm-dd')           <isNotEmpty prepend="and" property="zcwlh">zcwlh like $zcwlh$</isNotEmpty>         group by rksj, zcwlh) t group by zcwlh order by zcwlh</select>


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.