日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
MySQL數(shù)據(jù)庫(kù)NULL值的處理

我們大家都知道MySQL數(shù)據(jù)庫(kù)NULL其有非常獨(dú)特的邏輯意義,對(duì)于NULL值的處理問(wèn)題可以說(shuō)是令人一大頭疼的事情,所以今天我特意整理了一些比較實(shí)用的TIPS,希望會(huì)給你帶來(lái)一些幫助在此方面,疏漏之處敬請(qǐng)批評(píng) 。

成都創(chuàng)新互聯(lián)是專業(yè)的瑞麗網(wǎng)站建設(shè)公司,瑞麗接單;提供做網(wǎng)站、網(wǎng)站設(shè)計(jì),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行瑞麗網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

1. 對(duì)含空值列進(jìn)行排序

建表:

 
 
 
  1. mysql> create table t1(col1 int primary key, col2 varchar(2),col3 int);   
  2. Query OK, 0 rows affected (0.24 sec)  

加入數(shù)據(jù):

 
 
 
  1. mysql> insert into t1 values (1,'A',10),(2,'B',NULL),(3,'C',NULL),(4,'D',50),(5,'E',30),(6,'F',NULL),(7,'G',20),(8,'H',90),(9,'I',NULL),(10,'J',60);   
  2. Query OK, 10 rows affected (0.08 sec)   
  3. Records: 10 Duplicates: 0 Warnings: 0  

我們知道MySQL在排序過(guò)程中總是將NULL當(dāng)作“最小值”處理。例如:

 
 
 
  1. mysql> select * FROM t1 order by 3;   
  2. +------+------+------+   
  3. | col1 | col2 | col3 |   
  4. +------+------+------+   
  5. | 6 | F | NULL |   
  6. | 2 | B | NULL |   
  7. | 3 | C | NULL |   
  8. | 9 | I | NULL |   
  9. | 1 | A | 10 |   
  10. | 7 | G | 20 |   
  11. | 5 | E | 30 |   
  12. | 4 | D | 50 |   
  13. | 10 | J | 60 |   
  14. | 8 | H | 90 |   
  15. +------+------+------+   
  16. 10 rows in set (0.00 sec)   

但是,怎樣實(shí)現(xiàn)如下效果呢:

 
 
 
  1. +------+------+------+   
  2. | col1 | col2 | col3 |   
  3. +------+------+------+   
  4. | 1 | A | 10 |   
  5. | 7 | G | 20 |   
  6. | 5 | E | 30 |   
  7. | 4 | D | 50 |   
  8. | 10 | J | 60 |   
  9. | 8 | H | 90 |   
  10. | 2 | B | NULL |   
  11. | 3 | C | NULL |   
  12. | 6 | F | NULL |   
  13. | 9 | I | NULL |   
  14. +------+------+------+  
  15. 10 rows in set (0.00 sec)   
  16. SOLUTION:   
  17. mysql> SELECT col1, col2, col3 FROM (   
  18. -> SELECT col1, col2, col3,CASE WHEN col3 IS NULL THEN 0 ELSE 1 END AS IS_NULL FROM t1) as n   
  19. -> ORDER BY n.IS_NULL DESC, col3;  

運(yùn)用 'CASE'表達(dá)式構(gòu)造一個(gè)附加列,并為空值和非空值分別賦值,然后以該附加列作為排序條件。

 
 
 
  1. mysql> select col1, col2, col3,CASE WHEN col3 IS NULL THEN 0 ELSE 1 END AS IS_NULL FROM t1;   
  2. +------+------+------+---------+ |  
  3. | col1 | col2 | col3 | IS_NULL |   
  4. +------+------+------+---------+   
  5. | 1 | A | 10 | 1 |   
  6. | 2 | B | NULL | 0 |   
  7. | 3 | C | NULL | 0 |   
  8. | 4 | D | 50 | 1 |   
  9. | 5 | E | 30 | 1 |   
  10. | 6 | F | NULL | 0 |  
  11. | 7 | G | 20 | 1 |   
  12. | 8 | H | 90 | 1 |   
  13. | 9 | I | NULL | 0 |   
  14. | 10 | J | 60 | 1 |   
  15. +------+------+------+---------+   
  16. 10 rows in set (0.00 sec)   

通過(guò)構(gòu)造附加列對(duì)含MySQL數(shù)據(jù)庫(kù)NULL列排序,可以輕松決定含空值的記錄在結(jié)果集中的位置。

2. 運(yùn)用 ORDER BY NULL 禁止排序

若查詢中包含 GROUP BY 但我們希望避免對(duì)結(jié)果集排序從而減少消耗,可以運(yùn)用 ORDER BY NULL 禁止排序。

 
 
 
  1. R,'` A.Kk   
  2. mysql> EXPLAIN SELECT SUM(col3),CASE WHEN col3 IS NULL THEN 0 ELSE 1 END AS IS_NULL FROM t1 GROUP BY IS_NULL\G;  

1. row

 
 
 
  1. id: 1   
  2. select_type: SIMPLE   
  3. table: t1   
  4. type: ALL    
  5. possible_keys: NULL   
  6. key: NULL   
  7. key_len: NULL   
  8. ref: NULL   
  9. rows: 10   
  10. Extra: Using temporary; Using filesort   
  11. 1 row in set (0.00 sec)   
  12. mysql> EXPLAIN SELECT SUM(col3),CASE WHEN col3 IS NULL THEN 0 ELSE 1 END AS IS_NULL FROM t1 GROUP BY IS_NULL m)ORDER BY NULL\G;   

1. row

 
 
 
  1. id: 1   
  2. select_type: SIMPLE   
  3. table: t1   
  4. type: ALL   
  5. possible_keys: NULL   
  6. key: NULL   
  7. key_len: NULL ts   
  8. ref: NULL   
  9. rows: 10   
  10. Extra: Using temporary   
  11. 1 row in set (0.00 sec)  

可見(jiàn)運(yùn)用了ORDER BY NULL后查詢便沒(méi)有進(jìn)行filesort,在較大結(jié)果集中filesort操作往往相當(dāng)耗時(shí)。

3. 子查詢 NOT IN 與 NOT EXISTS 中的NULL

有些情況下 NOT IN 形式的子查詢返回空結(jié)果集,但是將其改寫為 NOT EXISTS 形式后則恢復(fù)正常,如下所示:
建表:

 
 
 
  1. mysql> CREATE TABLE t2 (col1 int default NULL, col2 int default NULL);   
  2. Query OK, 0 rows affected (0.01 sec)   
  3. mysql> CREATE TABLE t3 (col1 int default NULL, col2 int default NULL);   
  4. Query OK, 0 rows affected (0.01 sec)  

加入數(shù)據(jù):

 
 
 
  1. mysql> INSERT INTO t2 VALUES (1,2),(1,3);   
  2. Query OK, 2 rows affected (0.00 sec)   
  3. Records: 2 Duplicates: 0 Warnings: 0   
  4. mysql> INSERT INTO t3 VALUES (1,2),(1,NULL);   
  5. Query OK, 2 rows affected (0.00 sec)   
  6. Records: 2 Duplicates: 0 Warnings: 0  

執(zhí)行如下查詢:

 
 
 
  1. mysql> SELECT * FROM t2 WHERE col2 NOT IN (SELECT col2 FROM t3);   
  2. Empty set (0.00 sec)   
  3. mysql> SELECT * FROM t2 WHERE NOT EXISTS (SELECT 1 FROM t3 WHERE t3.col2 = t2.col2);   
  4. +------+------+   
  5. | col1 | col2 |   
  6. +------+------+   
  7. | 1 | 3 |   
  8. +------+------+   
  9. 1 row in set (0.00 sec)  

為什么會(huì)這樣呢?這要從MySQL數(shù)據(jù)庫(kù)NULL的特殊性說(shuō)起:

在MySQL中有三種狀態(tài):True、False、Unknown,任何NULL的比較操作都是Unknown狀態(tài),如下所示:

 
 
 
  1. mysql> SELECT 1 = NULL, 1 <> NULL, 1 < NULL, 1 > NULL;   
  2. +----------+-----------+----------+----------+   
  3. | 1 = NULL | 1 <> NULL | 1 < NULL | 1 > NULL |   
  4. +----------+-----------+----------+----------+   
  5. | NULL | NULL | NULL | NULL |   
  6. +----------+-----------+----------+----------+   
  7. 1 row in set (0.00 sec)  

而且所有的查詢條件(ON, WHERE, HAVING)都是將Unknown狀態(tài)當(dāng)做False處理。

所以***條查詢的查詢田間等同于:col2 NOT IN (2, NULL) => col2 <> 2 AND col2 <> NULL => true AND Unknow => Unknow => False
查詢條件永為False,故該查詢沒(méi)有返回結(jié)果。

而 NOT EXISTS 是循環(huán)執(zhí)行的

他首先執(zhí)行 SELECT 1 FROM t3 WHERE t3.col2 = 2

返回了結(jié)果,經(jīng) NOT EXISTS 操作后查詢條件為 False,故不做任何輸出,

接下來(lái)執(zhí)行 SELECT 1 FROM t3 WHERE t3.col2 = 3

無(wú)返回結(jié)果。經(jīng) NOT EXISTS 操作后查詢條件為 True,于是輸出本次查詢結(jié)果。

所以,如果當(dāng)一個(gè) NOT IN 子查詢沒(méi)有返回結(jié)果的時(shí)候,應(yīng)該特別注意內(nèi)層查詢的結(jié)果集是否包含空值,若包含的話,應(yīng)嘗試將查詢改寫為 NOT EXISTS 形式。

這種做法在有些情況下還可導(dǎo)致性能的提升。以上的相關(guān)內(nèi)容就是對(duì)MySQL數(shù)據(jù)庫(kù)NULL 的介紹,望你能有所收獲。

【編輯推薦】

  1. MySQL mysqldump命令的正確應(yīng)用
  2. 使用MySQL 數(shù)據(jù)庫(kù)出現(xiàn)的困難解決
  3. jsp MySQL 中的中文問(wèn)題的產(chǎn)生與解決
  4. MySQL命令導(dǎo)數(shù)據(jù)的實(shí)際操作與代碼
  5. 用c語(yǔ)言正確讀取MySQL數(shù)據(jù)庫(kù)實(shí)戰(zhàn)演示

當(dāng)前名稱:MySQL數(shù)據(jù)庫(kù)NULL值的處理
文章分享:http://www.5511xx.com/article/dphooji.html