亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

java - 如何解決where name like ’%%’ 當name 為null時,查詢不到數據?

瀏覽:109日期:2024-02-18 14:50:47

問題描述

問題解答

回答1:

SELECT

*

FROM

test

WHERE

1 = 1

AND NAME LIKE concat(

’%’,( CASE WHEN NAME(傳進來的name) IS NULL THEN’#################’(數據庫name不可能的值) ELSENAME(傳進來的name) END),’%’)

寫了一個name的排查,另外一個你自己看嘛,應該不是最好的解決方案

回答2:

可以在業務邏輯里寫,不一定非得在sql

回答3:

不知道有沒有使用數據庫框架,如果用到的話一般都有相應的解決方法。比如mybatis的話可以使用 iftest 判斷是否需要執行like語句。

還有一種方法是利用數據庫本身的函數 比如 IF(expr1,expr2,expr3) 或者IF ELSE之類的

回答4:

如果前臺沒有輸入參數,為什么要查詢該字段的結果呢?這不是不符合業務邏輯?

回答5:

where IFNULL(name, ’’) like’%xx%’ and IFNULL(method, ’’) like ’%xx%’如果name為null將其轉換為empty string那%%就能匹配上了。

不過我認為最好的做法還是使用SQL的地方增加邏輯判斷會比較好一些,改動量應該非常少,只需要幾句代碼就搞定了。題主可以看看@家常菜 的SQL增加一個where 1=1的條件,那if條件增加條件就會非常容易了。

回答6:

最好是寫在業務邏輯層(這層本來就是干這個的),這種事情不要到數據庫層再處理,這樣很不合理也很沒有效率。

回答7:

簡單的辦法,把表中值null轉為’’where ifnull(name,’’) like’%%’ and ifnull(method,’’) like ’%%’不考慮效率的話這樣就可以了

回答8:

題主是想簡單地把界面上的查詢條件拼接為SQL語句的Where條件,這樣在程序處理上確實很方便,不過出于安全考慮,最好不要這么做啦,因為有SQL注入的風險。

如果是內部應用,環境確實很安全,考慮到性能,也還是建議在拼接SQL的代碼邏輯上處理一下,沒有這個參數就不要拼對應的where子句,比如如果是Java,可以寫成:

String whereClause = 'where xxxxxx' +(''.equals(nameStr) ? '' : 'name like ’%'+nameStr+'%’') +(''.equals(methodStr) ? '' : 'method like ’%'+methodStr+'%’')

*這里是假設:

nameStr和methodStr分別是從界面上獲取的用戶輸入內容,如果用戶沒有輸入,得到的是空字符串,而不是null

xxxxxx是其他的where條件,如果真的其他條件都沒有,那還需要處理一下“where ”字符串本身*

回答9:

如果 數據庫默認值就是 null ,或者,當獲取到值為 null 時,修改為 nu。。

回答10:

where name=’’ or method =’’ or name like’%%’ and method like ’%%’

標簽: java
主站蜘蛛池模板: 国产精品亚洲一区二区三区在线播放 | 亚洲美女aⅴ久久久91 | 免费观看爱爱视频 | 无人区二区三区地址 | 国产亚洲欧美视频 | 亚洲精品综合久久 | 日本免费va毛片在线看大 | 妞干网在线视频观看 | 欧美一级久久久久久久大 | 成人中文字幕在线高清 | 国产香蕉在线观看 | 激情五月色综合婷婷大片 | 一区二区三区在线看 | 窝窝午夜色视频国产精品东北 | 96视频网站 | 无遮挡男女啪啪成人免费 | 99久久免费中文字幕精品 | 亚洲午夜久久久久久91 | 污污网站免费在线观看 | 欧美激情一区二区 | 国产毛片一级国语版 | 人人草人人干 | 日本69xxxx免费视频 | 999久久精品国产 | 久久精品www | 久久久久久福利 | 免费精品美女久久久久久久久 | 在线精品国内外视频 | 多女多p多杂交视频在线观看 | 日本一级aaaa特黄毛片 | 亚洲精品一区二区三区婷婷月 | 免费一级特黄特色黄大任片 | 免费中文字幕不卡视频 | 五月桃花网婷婷亚洲综合 | 污视频免费网站 | 亚洲1区2区3区4区 | 亚洲国产日韩在线人成蜜芽 | 99久久久久国产精品免费 | 国产挤奶水在线视频播放 | 久久综合色之久久综合 | 免费xxxxx大片观看 |