首頁 > 資料庫 > mysql教程 > MySQL中字串和數字的比較(附範例)

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

不言
發布: 2018-12-21 10:22:13
轉載
4088 人瀏覽過

這篇文章帶給大家的內容是關於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
登入後複製

#

以上是MySQL中字串和數字的比較(附範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板