日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

5、jeecg 笔记之 minidao 条件判断

發(fā)布時間:2023/12/10 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 5、jeecg 笔记之 minidao 条件判断 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?1、前言

我們知道?mybatis?中的動態(tài)sql語句是基于 OGNL 表達式的。 額外補充一點:mybatis?中的 #{} 和 ${} ,可直接跳過。 #{}表示一個占位符號,#{}接收輸入?yún)?shù),類型可以是簡單類型,pojo、hashmap。 如果接收簡單類型,#{}中可以寫成value或其它名稱。 #{}接收pojo對象值,通過OGNL讀取對象中的屬性值,通過屬性.屬性.屬性...的方式獲取對象屬性值。${}表示一個拼接符號,會引用sql注入,所以不建議使用${}。 ${}接收輸入?yún)?shù),類型可以是簡單類型,pojo、hashmap。 如果接收簡單類型,${}中只能寫成value。 ${}接收pojo對象值,通過OGNL讀取對象中的屬性值,通過屬性.屬性.屬性...的方式獲取對象屬性值。

?來看看今天的重點對象,minidao,那么它里邊的語法又是什么呢?

2、怎么寫

怎么寫之前先來看一下官方的描述: Jeecg針對springjdbc+freemarker做了封裝,出了這么一個輕量級持久層,可以讓Hiberate擁有mybatis一樣SQL靈活能力,同時支持事務統(tǒng)一、SQL標簽能力。 這樣是不是已經(jīng)很明確了呢,freemarker?語法,那么 freemaker?是什么呢? freemaker 是前端引擎,只負責展示,沒有復雜邏輯,而它的語法是 FTL?指令,類似于 HTML?標簽。 來看看 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?進行遍歷

<#list items as item>${item.userName} </#list> 更加詳細的參考:http://qy85.iteye.com/blog/1612093?

3、需要注意

既然我們知道了, minidao?中,封裝了 freemaker 便簽,那么同樣我們也知道,在 freemaker ftl中,參數(shù)是通過 ${},而我們在系統(tǒng)發(fā)現(xiàn),很多都是這樣用的 :參數(shù),那么這又是怎么一回事?

4、sql 參數(shù)使用方式

?

?4.1 占位符方式-【:字段名】

?這種方式是我們在系統(tǒng)中最常見的了,來看看他的與缺點。

?優(yōu)點: 防止sql注入;sql執(zhí)行計劃只解析一次;字段值根據(jù)類型自動轉(zhuǎn)換,不需要手工處理

?缺點: 只能傳參數(shù)原生態(tài)值;參數(shù)為List情況循環(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 模版語言方式 -【${字段名}】

你要的 ftl 方式的來了。

缺點: Sql直接拼裝,有SQL注入風險;參數(shù)值需根據(jù)類型手工轉(zhuǎn)換;

優(yōu)點: 可以對參數(shù)值進行腳本處理;參數(shù)為List對象,循環(huán)體對象必須用該方式;(用戶體驗沒有變化,直接將${}改為: 即可)

特點: 持多參數(shù),支持參數(shù)多層,參數(shù)為list必須采用模板語言方式

官方示例:

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??#{} 和 ${} ,其實為了體現(xiàn) :字段名 和? ${}

總之,推薦使用占位符的形式。

?

http://minidao.mydoc.io/?t=293640

總結(jié)

以上是生活随笔為你收集整理的5、jeecg 笔记之 minidao 条件判断的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。