久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

mybatis框架order by作為參數傳入時失效的解決

瀏覽:17日期:2023-10-19 09:23:17
mybatis order by作為參數傳入失效

mxl中的語句如下

<select resultType='com.dahua.la.business.model.vo.StatSysResultVO'> select a, b,count(1) as total from table where a is not null and b is not null and operateTime >= #{startTime,jdbcType=TIMESTAMP} and operateTime <= #{endTime,jdbcType=TIMESTAMP} group by a, b order by <foreach collection='orderItems' item='item' separator=','> #{item.orderBy} #{item.order} </foreach></select>

運行時通過日志打印出sql日志如下

select a, b, count(1) as total from table where a is not null and b is not null and operateTime >= ? and operateTime <= ? group by a, b order by ? ?

把參數補充上拿到Navicat執行的時候,完全沒有問題,排序也正常。

但是在代碼里執行就是不行, 最后的排序完全沒有生效。

實際上,我補上參數的時候漏了引號,因為#{item.orderBy}會對傳入的數據加一個引號,如果帶著引號去Navicat執行,也是排序不生效的。

問題原因找到了

直接替換成使用${item.orderBy}形式,單純的字符串替換不加引號。

<foreach collection='orderItems' item='item' separator=','> ${item.orderBy} ${item.order}</foreach>

此時程序正常。

MyBatis排序時使用order by 動態參數時需要注意,用$而不是#

字符串替換

默認情況下,使用#{}格式的語法會導致MyBatis創建預處理語句屬性并以它為背景設置安全的值(比如?)。

這樣做很安全,很迅速也是首選做法,有時你只是想直接在SQL語句中插入一個不改變的字符串。

比如,像ORDER BY,你可以這樣來使用:

ORDER BY ${columnName}

這里MyBatis不會修改或轉義字符串。

重要:

接受從用戶輸出的內容并提供給語句中不變的字符串,這樣做是不安全的。

這會導致潛在的SQL注入攻擊,因此你不應該允許用戶輸入這些字段,或者通常自行轉義并檢查。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 国产精品亚洲综合 | 亚洲精品久久久蜜臀 | 中文日韩av | 天天干国产 | 国产一区不卡 | 色婷婷精品国产一区二区三区 | 亚洲+变态+欧美+另类+精品 | 成人亚洲| 日本少妇bbbb爽爽bbb美 | 成年人福利 | 日本三级中国三级99人妇网站 | 国产乱码精品一区二区三区忘忧草 | www日韩欧美 | 精品国产福利 | 亚洲精品乱码8久久久久久日本 | 日日夜夜免费精品视频 | 精品视频一区二区三区在线观看 | 午夜老湿影院 | 久久伦理电影 | 国产一区二区三区久久久久久 | 亚洲成人中文字幕 | 欧美一区二区三区aa大片漫 | 成人性大片免费观看网站 | 国产精品一区二区三区四区 | 国产欧美一区二区视频 | 欧美综合激情 | 国产日韩成人 | 欧美xxxx色视频在线观看免费 | av电影中文字幕在线观看 | 国产精品日韩 | 欧美日韩中文字幕 | 日本中文在线 | 黄色毛片在线看 | 亚洲精品久久久久久国产精华液 | 成人精品鲁一区一区二区 | 在线精品亚洲欧美日韩国产 | 国产女人爽到高潮免费视频 | 欧美日韩精品久久久 | 亚洲国产精品久久人人爱 | 热re99久久精品国产99热 | av免费在线观看网站 |