簡體   English   中英

來自查詢的錯誤結果

[英]Wrong result from query

我有這個簡單的查詢

SELECT * 
FROM  `book` 
WHERE  `BookID` =  '7u'
LIMIT 1

我期待空結果但我看到一個結果,書ID = 7。 BookID是自動增量。 為什么查詢忽略'u'字符?

因為7u不是數字,所以顯然mysql忽略了u

也許您正在考慮一些使用后綴來限定數字類型的高級編程語言? 在C派生語言中,7u是無符號整數,值為7。

僅僅因為兩個原因:

  1. 可能只有一條記錄。

  2. 你使用的是LIMIT 1.它只顯示輸出中的一條記錄。 所以使用LIMIT 5或2。

mysql將字符串作為7u,所以當你嘗試做這個東西時它會在一個字符串中轉換但是mysql不是在嚴格模式下所以它將字符串轉換為整數因為你的id是整數而它的7u的舍入變為7這就是為什么它顯示為一個記錄嘗試沒有引用7u而不是'7u'然后它給出錯誤

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM