亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

mysql語句%和=執行結果的區別

mysql語句%和=執行結果的區別

繁華開滿天機 2018-07-06 15:18:24
SELECT count(1) FROM media_info where media_id = '%'+'bb'+'%'SELECT count(1) FROM media_info where media_id like CONCAT('%','bb','%')今天在做統計的時候突然發現了這個問題。關于%拼接的問題。數據庫返回的數據條數竟然不一致。而且還驚奇的發現 第一條語句返回的結果中有些并不存在bb關鍵字,想問這種差異是怎么產生的,一般情況我們進行模糊查詢時,用那種方式,謝謝了呢。
查看完整描述

2 回答

?
繁星coding

TA貢獻1797條經驗 獲得超4個贊

后來自己根據一樓做了測試,首先執行了一下兩個語句
SELECT * FROM media_info WHERE media_id = 0

SELECT * FROM media_info WHERE media_id = '%'+'bb'+'%'

發現結果相同,業績證實了,@范捷琦Jackie的說法是正確的,在這樣情況下會將media強制轉化為為0整數,而【'%'+'bb'+'%'】這個值也是為零的。然后我又做了一下測試【SELECT * FROM media_info WHERE media_id =1】,然后發現匹配出來的是media_id以1開頭的數據,所以猜測應該是,【當利用=進行整數判斷時,會根據你所匹配的值,來進行首字母匹配對應的數據】


查看完整回答
反對 回復 2018-07-14
?
小唯快跑啊

TA貢獻1863條經驗 獲得超2個贊

首先,('%'+'bb'+'%')沒啥意義,其結果為0。它跟字符串做等于比較時,字符串media_id會強制轉化為整數,除非這個字符串是'1',轉化下來1才不等于0,否則media_id總會是轉化為0,所以不能這么用。
你可以具體試試:

SELECT 

'' = ('%'+'g'+'%'),

'a' = ('%'+'g'+'%'),

'abc' = ('%'+'g'+'%'),

'1' = ('%'+'g'+'%')

;

做模糊查詢,只能用你列的第二種方式。


查看完整回答
反對 回復 2018-07-14
  • 2 回答
  • 0 關注
  • 174 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號