MySQL中字符串和數字的比較(附示例)

本篇文章給大家帶來的內容是關于mysql中字符串和數字的比較(附示例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

在項目中,我們經常會用到模糊搜索,但如果錯誤的將字符串類型和數字類型做比較,有時搜索出來的結果就并不是我們預期的。舉例如下:

mybatis中的xml語句如下:

<if test="criteria != null and criteria.length()>0">     AND (name like concat("%",#{criteria},"%") OR id = #{criteria}) </if>

搜索時我們輸入“884測試”,結果會包含了id=884的記錄,但是名稱卻沒有匹配的。這就是mysql字符串和數字比較的坑了:比較時會把字符串類型轉成整數類型,從首字母開始,遇到非數字類型后終止。

舉幾個例子看下:

SELECT "abc"=1; 結果:0
SELECT "1abc"=1; 結果:1
SELECT "abc"=0; 結果:1
SELECT "a2bc"=2; 結果:0

那么這個問題改如何解決了,其實只需要做一個類型轉換就可以了,如下:

SELECT "2bc"=cast(2 as CHAR); 結果:0

? 版權聲明
THE END
喜歡就支持一下吧
點贊13 分享