5、jeecg 笔记之 minidao 条件判断
?1、前言
我們知道?mybatis?中的動(dòng)態(tài)sql語(yǔ)句是基于 OGNL 表達(dá)式的。 額外補(bǔ)充一點(diǎn):mybatis?中的 #{} 和 ${} ,可直接跳過(guò)。 #{}表示一個(gè)占位符號(hào),#{}接收輸入?yún)?shù),類型可以是簡(jiǎn)單類型,pojo、hashmap。 如果接收簡(jiǎn)單類型,#{}中可以寫(xiě)成value或其它名稱。 #{}接收pojo對(duì)象值,通過(guò)OGNL讀取對(duì)象中的屬性值,通過(guò)屬性.屬性.屬性...的方式獲取對(duì)象屬性值。${}表示一個(gè)拼接符號(hào),會(huì)引用sql注入,所以不建議使用${}。 ${}接收輸入?yún)?shù),類型可以是簡(jiǎn)單類型,pojo、hashmap。 如果接收簡(jiǎn)單類型,${}中只能寫(xiě)成value。 ${}接收pojo對(duì)象值,通過(guò)OGNL讀取對(duì)象中的屬性值,通過(guò)屬性.屬性.屬性...的方式獲取對(duì)象屬性值。?來(lái)看看今天的重點(diǎn)對(duì)象,minidao,那么它里邊的語(yǔ)法又是什么呢?
2、怎么寫(xiě)
怎么寫(xiě)之前先來(lái)看一下官方的描述: Jeecg針對(duì)springjdbc+freemarker做了封裝,出了這么一個(gè)輕量級(jí)持久層,可以讓Hiberate擁有mybatis一樣SQL靈活能力,同時(shí)支持事務(wù)統(tǒng)一、SQL標(biāo)簽?zāi)芰Α? 這樣是不是已經(jīng)很明確了呢,freemarker?語(yǔ)法,那么 freemaker?是什么呢? freemaker 是前端引擎,只負(fù)責(zé)展示,沒(méi)有復(fù)雜邏輯,而它的語(yǔ)法是 FTL?指令,類似于 HTML?標(biāo)簽。 來(lái)看看 minidao?中怎么用吧。2.1 if?判斷
<#if status?exists && status?length gt 0>and t.status= :status </#if>?
2.2 if elese?
<#if status?exists && status?length gt 0>and t.status= :status <#else>and 1=1 </#if>2.3 list?進(jìn)行遍歷
<#list items as item>${item.userName} </#list> 更加詳細(xì)的參考:http://qy85.iteye.com/blog/1612093?3、需要注意
既然我們知道了, minidao?中,封裝了 freemaker 便簽,那么同樣我們也知道,在 freemaker ftl中,參數(shù)是通過(guò) ${},而我們?cè)谙到y(tǒng)發(fā)現(xiàn),很多都是這樣用的 :參數(shù),那么這又是怎么一回事?4、sql 參數(shù)使用方式
?
?4.1 占位符方式-【:字段名】
?這種方式是我們?cè)谙到y(tǒng)中最常見(jiàn)的了,來(lái)看看他的與缺點(diǎn)。
?優(yōu)點(diǎn): 防止sql注入;sql執(zhí)行計(jì)劃只解析一次;字段值根據(jù)類型自動(dòng)轉(zhuǎn)換,不需要手工處理
?缺點(diǎn): 只能傳參數(shù)原生態(tài)值;參數(shù)為L(zhǎng)ist情況循環(huán)體不適用
?官方示例:
SELECT * FROM employee where 1=1 <#if employee.age ?exists> and age = :employee.age </#if> <#if employee.name ?exists> and name = :employee.name </#if> <#if employee.empno ?exists> and empno = :employee.empno </#if>?
4.2 模版語(yǔ)言方式 -【${字段名}】
你要的 ftl 方式的來(lái)了。
缺點(diǎn): Sql直接拼裝,有SQL注入風(fēng)險(xiǎn);參數(shù)值需根據(jù)類型手工轉(zhuǎn)換;
優(yōu)點(diǎn): 可以對(duì)參數(shù)值進(jìn)行腳本處理;參數(shù)為L(zhǎng)ist對(duì)象,循環(huán)體對(duì)象必須用該方式;(用戶體驗(yàn)沒(méi)有變化,直接將${}改為: 即可)
特點(diǎn): 持多參數(shù),支持參數(shù)多層,參數(shù)為list必須采用模板語(yǔ)言方式
官方示例:
SELECT * FROM employee where 1=1 <#if employee.age ?exists>and age = '${employee.age}' </#if> <#if employee.name ?exists>and name = '${employee.name}' </#if><#if employee.empno ?exists>and empno = '${employee.empno}' </#if>
?
上邊之所以提到 mybatis??#{} 和 ${} ,其實(shí)為了體現(xiàn) :字段名 和? ${}
總之,推薦使用占位符的形式。
?
http://minidao.mydoc.io/?t=293640總結(jié)
以上是生活随笔為你收集整理的5、jeecg 笔记之 minidao 条件判断的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 计算机课件白板培训,希沃白板使用教学,直
- 下一篇: 多态、抽象类