本篇內(nèi)容主要講解“MySQL的varchar與數(shù)值舉例分析”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“MYSQL的varchar與數(shù)值舉例分析”吧!
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、埇橋區(qū)網(wǎng)絡(luò)推廣、微信小程序定制開(kāi)發(fā)、埇橋區(qū)網(wǎng)絡(luò)營(yíng)銷(xiāo)、埇橋區(qū)企業(yè)策劃、埇橋區(qū)品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供埇橋區(qū)建站搭建服務(wù),24小時(shí)服務(wù)熱線:13518219792,官方網(wǎng)址:www.cdcxhl.com
好了來(lái)說(shuō)具體場(chǎng)景,被同事叫去看一個(gè)奇怪的SQL。SQL語(yǔ)句很簡(jiǎn)單,大概就是查詢某些字段有一些查詢條件而已。其中比較重要的一個(gè)條件就是 「where xx!=0」。說(shuō)是很奇怪,為什么!=0就查詢到的結(jié)果就是10條。但是!=1 查詢出來(lái)的結(jié)果就是100條。
SELECT A,B,C FROM TABLE WHERE A!=0
res:10
SELECT A,B,C FROM TABLE WHERE A!=0
res:100
下面我們簡(jiǎn)單的來(lái)幾條數(shù)據(jù)看一下?tīng)顩r。
「所有數(shù)據(jù)」
「!=0」
當(dāng)時(shí)就是直接拿到了這樣的結(jié)果。
當(dāng)時(shí)看到這個(gè)問(wèn)題之后我也很驚奇,不等于0 不應(yīng)該把所有的數(shù)據(jù)都拿到么。為什么會(huì)出現(xiàn)這樣的情況呢?
簡(jiǎn)單考慮了一下,字段的類型為 varchar型,而查詢條件給予的是個(gè)數(shù)值型,那么問(wèn)題應(yīng)該就是出現(xiàn)在這里。
數(shù)據(jù)庫(kù)在基于查詢條件進(jìn)行檢索的時(shí)候會(huì)如何進(jìn)行操作呢?
答案就是轉(zhuǎn)換成相同的類型。
那么對(duì)于這次的問(wèn)題是字段轉(zhuǎn)換成int類型還是int轉(zhuǎn)換成varchar類型呢?其實(shí)簡(jiǎn)單的看查詢結(jié)果就知道了。如果查詢條件‘0’轉(zhuǎn)換成了varchar那么就應(yīng)該獲取到全部的數(shù)據(jù)。但是現(xiàn)在的狀況是獲取到的數(shù)據(jù)不夠。那結(jié)論就是數(shù)據(jù)庫(kù)把要查詢的字段轉(zhuǎn)換成了數(shù)值型。
那么我們把a(bǔ)pp字段進(jìn)行轉(zhuǎn)換一下試試。
從結(jié)果上我們可以看到 app 轉(zhuǎn)換之后的結(jié)果只有 0123asfj 轉(zhuǎn)換成了123,其他都是0。所以在查詢條件為 ‘!=0’ 的時(shí)候就只能查詢到一條結(jié)果。
到此,相信大家對(duì)“MYSQL的varchar與數(shù)值舉例分析”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!