av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java - 如何解決where name like ’%%’ 當(dāng)name 為null時(shí),查詢不到數(shù)據(jù)?

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

問(wèn)題描述

問(wèn)題解答

回答1:

SELECT

*

FROM

test

WHERE

1 = 1

AND NAME LIKE concat(

’%’,( CASE WHEN NAME(傳進(jìn)來(lái)的name) IS NULL THEN’#################’(數(shù)據(jù)庫(kù)name不可能的值) ELSENAME(傳進(jìn)來(lái)的name) END),’%’)

寫了一個(gè)name的排查,另外一個(gè)你自己看嘛,應(yīng)該不是最好的解決方案

回答2:

可以在業(yè)務(wù)邏輯里寫,不一定非得在sql

回答3:

不知道有沒(méi)有使用數(shù)據(jù)庫(kù)框架,如果用到的話一般都有相應(yīng)的解決方法。比如mybatis的話可以使用 iftest 判斷是否需要執(zhí)行l(wèi)ike語(yǔ)句。

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

回答4:

如果前臺(tái)沒(méi)有輸入?yún)?shù),為什么要查詢?cè)撟侄蔚慕Y(jié)果呢?這不是不符合業(yè)務(wù)邏輯?

回答5:

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

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

回答6:

最好是寫在業(yè)務(wù)邏輯層(這層本來(lái)就是干這個(gè)的),這種事情不要到數(shù)據(jù)庫(kù)層再處理,這樣很不合理也很沒(méi)有效率。

回答7:

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

回答8:

題主是想簡(jiǎn)單地把界面上的查詢條件拼接為SQL語(yǔ)句的Where條件,這樣在程序處理上確實(shí)很方便,不過(guò)出于安全考慮,最好不要這么做啦,因?yàn)橛蠸QL注入的風(fēng)險(xiǎn)。

如果是內(nèi)部應(yīng)用,環(huán)境確實(shí)很安全,考慮到性能,也還是建議在拼接SQL的代碼邏輯上處理一下,沒(méi)有這個(gè)參數(shù)就不要拼對(duì)應(yīng)的where子句,比如如果是Java,可以寫成:

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

*這里是假設(shè):

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

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

回答9:

如果 數(shù)據(jù)庫(kù)默認(rèn)值就是 null ,或者,當(dāng)獲取到值為 null 時(shí),修改為 nu。。

回答10:

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

標(biāo)簽: java
主站蜘蛛池模板: 国产视频1区 | 国产视频中文字幕 | 亚洲精品www久久久久久广东 | 中文字幕第5页 | 日韩av第一页 | 激情欧美日韩一区二区 | 黄色大片在线视频 | 成人午夜免费网站 | av一区二区三区四区 | 污免费网站 | 欧美福利 | 成人精品 | 欧美久久一区 | 精品福利一区二区三区 | 久久99深爱久久99精品 | 久久九精品 | 国产a视频| 日本视频一区二区 | 成人精品一区二区三区 | 99pao成人国产永久免费视频 | 国产一区二区在线播放 | 成人精品一区二区三区 | 亚洲二区在线观看 | 欧美在线视频免费 | 激情91| 欧美天堂| 久久毛片 | 人人擦人人 | 午夜无码国产理论在线 | 91精品久久久久久久久中文字幕 | 色视频一区二区 | 精品国产乱码久久久久久牛牛 | 在线成人免费视频 | 不卡一区二区三区四区 | 日韩国产欧美 | 亚洲成网| 日韩一区二区三区在线观看 | 日本黄色大片免费 | 国产成人艳妇aa视频在线 | 中文字幕视频在线观看 | 亚洲欧美少妇 |