查詢字段為空的數(shù)據(jù)。如下三條語句查詢的結(jié)果各不相同。
成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務,包含不限于成都網(wǎng)站設計、網(wǎng)站建設、安定網(wǎng)絡推廣、成都微信小程序、安定網(wǎng)絡營銷、安定企業(yè)策劃、安定品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)為所有大學生創(chuàng)業(yè)者提供安定建站搭建服務,24小時服務熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
select count(0) from tps_uw_detail where trim(coreContNo)=''; ###1736
select count(0) from? tps_uw_detail where coreContNo is null; ###735
select count(0) from? tps_uw_detail where (coreContNo is null or trim(coreContNo)='');##2471
='';就是存的空字符串;is null 就是默認的。
由于是后來新加的字段,默認為null,所以歷史數(shù)據(jù)都為null。表中加上這個字段后,再落庫的數(shù)據(jù)就是空字符串了。
根據(jù)自己的需求選用腳本,第三個是適合我的。
1.IF()函數(shù)的使用
IF(expr1,expr2,expr3),如果expr1的值為true,則返回expr2的值,如果expr1的值為false,則返回expr3的值。
SELECT IF(TRUE,'A','B'); -- 輸出結(jié)果:A
SELECT IF(FALSE,'A','B'); -- 輸出結(jié)果:B12
2.IFNULL()函數(shù)的使用
IFNULL(expr1,expr2),如果expr1的值為null,則返回expr2的值,如果expr1的值不為null,則返回expr1的值。
SELECT IFNULL(NULL,'B'); -- 輸出結(jié)果:B
SELECT IFNULL('HELLO','B'); -- 輸出結(jié)果:HELLO12
3.NULLIF()函數(shù)的使用
NULLIF(expr1,expr2),如果expr1=expr2成立,那么返回值為null,否則返回值為expr1的值。
SELECT NULLIF('A','A'); -- 輸出結(jié)果:null
SELECT NULLIF('A','B'); -- 輸出結(jié)果:A12
4.ISNULL()函數(shù)的使用
ISNULL(expr),如果expr的值為null,則返回1,如果expr1的值不為null,則返回0。
SELECT ISNULL(NULL); -- 輸出結(jié)果:1
SELECT ISNULL('HELLO'); -- 輸出結(jié)果:0
null表示的含義是未知,即不知道有沒有。 和‘’空字符串不等,因為空字符串相當于沒有值。 null代表的是不知道有沒有值。 所以在數(shù)據(jù)查詢中如果字段默認值是null,想查詢出不等于某個條件的一定要加上——字段名 is null 或者字段名 is not null來...
空值是一個比較特殊的字段。在MySQL數(shù)據(jù)庫中,在不同的情形下,空值往往代表不同的含義。這是MySQL數(shù)據(jù)庫的一種特性。如在普通的字段中(字符型的數(shù)據(jù)),空值就是表示空值。但是如果將一個空值的數(shù)據(jù)插入到TimesTamp類型的字段中,空值就不一定為空。此時為出現(xiàn)什么情況呢
我先創(chuàng)建了一個表。在這個表中有兩個字段:User_id(其數(shù)據(jù)類型是int)、Date(其數(shù)據(jù)類型是TimesTamp)?,F(xiàn)在往這個表中插入一條記錄,其中往Date字段中插入的是一個NULL空值??墒钱斘覀儾樵儠r,其結(jié)果顯示的卻是插入記錄的當前時間。這是怎么一回事呢?其實這就是在MySQL數(shù)據(jù)庫中執(zhí)行SQL語句時經(jīng)常會遇到的一個陷阱:空值不一定為空。在操作時,明明插入的是一個空值的數(shù)據(jù),但是最后查詢得到的卻不是一個空值。
在MySQL數(shù)據(jù)庫中,NULL對于一些特殊類型的列來說,其代表了一種特殊的含義,而不僅僅是一個空值。對于這些特殊類型的列,各位讀者主要是要記住兩個。一個就是筆者上面舉的TimesTamp數(shù)據(jù)類型。如果往這個數(shù)據(jù)類型的列中插入Null值,則其代表的就是系統(tǒng)的當前時間。另外一個是具有auto_increment屬性的列。如果往這屬性的列中插入Null值的話,則系統(tǒng)會插入一個正整數(shù)序列。而如果在其他數(shù)據(jù)類型中,如字符型數(shù)據(jù)的列中插入Null的數(shù)據(jù),則其插入的就是一個空值。