<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
然後像xml語法一樣書寫
@Select({"<script>", "SELECT * FROM tbl_order", "WHERE 1=1", "<when test='title!=null'>", "AND mydate = #{mydate}", "</when>", "</script>"})
例如:
public class OrderProvider { private final String TBL_ORDER = "tbl_order"; public String queryOrderByParam(OrderPara param) { SQL sql = new SQL().SELECT("*").FROM(TBL_ORDER); String room = param.getRoom(); if (StringUtils.hasText(room)) { sql.WHERE("room LIKE #{room}"); } Date myDate = param.getMyDate(); if (myDate != null) { sql.WHERE("mydate LIKE #{mydate}"); } return sql.toString(); } } public interface OrderDAO { @SelectProvider(type = OrderProvider.class, method = "queryOrderByParam") List<Order> queryOrderByParam(OrderParam param); }
注意:方式1有個隱患就是當傳入引數為空的時候,可能會造成全表查詢。
複雜SQL用方式2會比較靈活(當然,並不建議寫複雜SQL),而且可以抽象成通用的基礎類別,使每個DAO都可以通過這個基礎類別實現基本的通用查詢,原理類似Spring JDBC Template。
如果XML元素嵌入在<script>XML元素中,則可以在註釋值中為動態SQL使用XML元素:
@Select("<script>SELECT ...</script>")
但是使用<include>元素會觸發SQL Mapper設定解析異常,由以下原因引起:
org.apache.ibatis.builder.BuilderException: Unknown element in SQL statement. at org.apache.ibatis.scripting.xmltags.XMLScriptBuilder.parseDynamicTags
如果nodeHandlers在課堂中檢查方法org.apache.ibatis.builder.BuilderException,將注意到支援的元素有:
trim
where
set
foreach
if
choose
when
otherwise
bind
然而,包括基於註釋的查詢中的片段是不可能的。
說明:在mybatis 的sql裡不是不能寫註釋,而是註釋不能有#{},mybatis仍舊會把#{}算成一個帶注入的引數
如程式碼段2所示,mysql資料庫更換為oracle資料庫時,#{date}需要明確jdbcType,而該程式碼段中僅將適用於mysql的sql註釋,依舊會報同樣的錯,最好是將註釋的sql刪除。
<select id="slectSlagsteelRatioByDate" resultType="java.lang.Double"> -- select slagsteel_ratio FROM process_history WHERE r furnace_num = #{furnaceNum} -- ORDER BY real_time DESC limit 0,1 select slagsteel_ratio FROM( select slagsteel_ratio FROM process_history WHERE real_time <= #{date,jdbcType=TIMESTAMP} ORDER BY real_time DESC ) WHERE ROWNUM = 1 </select>
1、where語句等用到大於小於等符號時候,需要使用 <![CDATA[ > ]]>或者 <![CDATA[ < ]]>進行識別。
2、如果sql文中有動態sql文標籤,比如sql文,此時wwww為傳遞的引數,不需用#{wwww }取值,直接使用即可。
3、如果超過一個引數,需要在介面方法的每個引數定義時候使用@Param註解。
4、order by語句可以使用動態sql
ORDER BY eeee ORDER BY rrrrrr
5、SELECT
CASE WHEN 條件1 THEN 欄位1
WHEN 條件2 THEN 欄位2
ELSE 欄位3 END FROM.....
只要滿足一個WHEN,後面的WHEN就不會執行了,跳出CASE WHEN 語句
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45