MySQL系列关于NUll值的经验总结分析教程 |
1.娴嬭瘯鏁版嵁create table test_null ( id int, name varchar(20), chinese int, math int, english int ) charset=utf8; insert into test_null values (1,null,80,70,68), (2,'寮犱笁',60,null,null), (3,'鏉庡洓',null,90,80), (4,'鐜嬩簲',90,60,75), (5,null,null,50,95); 缁撴灉濡備笅锛?/p> 2.null鍊煎甫缁欐垜浠殑涓嶄究褰卞搷1锛夎繃婊ゆ湁鎵涓嶅悓锛屽彧鑳戒娇鐢╥s null鎴栬卛s not null锛?/p> # null鍊间笉鑳戒娇鐢?== 鎴?!= 鏉ユ瘮杈? # 涓嬮潰涓ょ鐢ㄦ硶閮芥槸閿欒鐨? select * from test_null where name == null; select * from test_null where name != null; # null鍊间竴鑸娇鐢?is null 鎴?is not null 鏉ユ瘮杈? # 涓嬮潰涓ょ鐢ㄦ硶鎵嶆槸姝g‘鐨? select * from test_null where name is null; select * from test_null where name is not null; 2锛夊嚭鐜皀ull鍊硷紝浼氬鑷? - * /杩愮畻澶辨晥锛?/p> select *,(chinese+math+english) as 鎬诲垎 from test_null; 缁撴灉濡備笅锛?/p> 3锛塶ull鍊煎鑱氬悎鍑芥暟鏃犲奖鍝嶏紝鑱氬悎鍑芥暟浼氱洿鎺ュ拷鐣ull鍊硷紱 select sum(chinese) 璇枃鎬诲垎, sum(math) 鏁板鎬诲垎, sum(english) 澶栬鎬诲垎 from test_null 缁撴灉濡備笅锛?/p> 3.绌烘牸銆佺┖鍊煎拰null锛屾垜浠簲璇ユ庝箞鍒ゆ柇鍛紵1锛夌┖鏍笺佺┖鍊煎拰null鐨勫尯鍒?/h3>鐢ㄤ竴涓舰璞$殑姣斿柣鏉ヨ鏄庤繖涓夎呯殑鍖哄埆銆傞鍏堢┖鏍煎緢濂界悊瑙o紝涓涓┖瀛楃涓插悧锛屽崰鎹竴瀹氱殑绌洪棿澶у皬銆備笉濂界悊瑙g殑鍏跺疄鏄┖鍊煎拰null锛岀┖鍊肩浉褰撲簬涓涓澂瀛愭槸鐪熺┖鐘舵佺殑锛屼粈涔堜篃娌℃湁锛宯ull琛ㄧず鐨勬澂瀛愪腑鏈夌┖姘斻?/p> MySQL涓紝 2锛夊嚭鐜颁簡null鍊硷紝鎴戝簲璇ユ庝箞鍔烇紵閫氳繃涓婇潰鐨勫垎鏋愭垜浠凡缁忕煡閬撲簡锛屽綋琛ㄤ腑瀛樺湪null鍊硷紝浼氬鑷村姞銆佸噺銆佷箻銆侀櫎杩愮畻澶辨晥銆傞偅涔堟垜浠庝箞澶勭悊杩欎簺null鍊兼瘮杈冨ソ鍛紵 绗竴绉嶆柟寮忥細鐩存帴浣跨敤is not null灏嗚繖浜沶ull鍊艰繃婊ゆ帀锛屼絾鏄繖鏍蜂細灏嗗叾瀹冮潪缂哄け鍊肩殑瀛楁杩囨护鎺夛紝閫犳垚鏁版嵁鐨勬氮璐广?/p> 绗簩绉嶆柟寮忥細涔熸槸鎴戜滑鎺ㄨ崘鐨勬柟寮忥紝鎴戜滑浣跨敤鍑芥暟杩涜缂哄け鍊肩殑濉厖銆?/p> ifnull()鍜宑oalesce()鍑芥暟鐨勪娇鐢細 select id, coalesce(name,'鏃犲悕姘?) name, coalesce(chinese,0) chinese, ifnull(math,0) math, ifnull(english,0) english from test_null; 缁撴灉濡備笅锛?/p> 浠ヤ笂灏辨槸MySQL绯诲垪鍏充簬NUll鍊肩殑缁忛獙鎬荤粨鍒嗘瀽鐨勮缁嗗唴瀹癸紝鏇村鍏充簬MySQL涓殑NUll鍊肩殑璧勬枡璇峰叧娉ㄨ剼鏈箣瀹跺叾瀹冪浉鍏虫枃绔狅紒 |