校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL為何不建議使用默認值為null列

MySQL為何不建議使用默認值為null列

熱門標簽:云南電商智能外呼系統價格 大眾點評星級酒店地圖標注 話務外呼系統怎么樣 400電話可以辦理嗎 拉卡拉外呼系統 臨清電話機器人 智能外呼系統復位 外東北地圖標注 高清地圖標注道路

通常能聽到的答案是使用了NULL值的列將會使索引失效,但是如果實際測試過一下,你就知道IS NULL會使用索引.所以上述說法有漏洞.

著急的人拉到最下邊看結論

Preface

Null is a special constraint of columns.
The columns in table will be added null constrain if you do not define the column with “not null” key words explicitly
when creating the table.Many programmers like to define columns by default
because of the conveniences(reducing the judgement code of nullibility) what consequently
cause some uncertainty of query and poor performance of database.

NULL值是一種對列的特殊約束,我們創建一個新列時,如果沒有明確的使用關鍵字not null聲明該數據列,Mysql會默認的為我們添加上NULL約束.
有些開發人員在創建數據表時,由于懶惰直接使用Mysql的默認推薦設置.(即允許字段使用NULL值).而這一陋習很容易在使用NULL的場景中得出不確定的查詢結果以及引起數據庫性能的下降.

Introduce

Null is null means it is not anything at all,we cannot think of null is equal to ‘' and they are totally different.
MySQL provides three operators to handle null value:“IS NULL”,“IS NOT NULL”,"=>" and a function ifnull().
IS NULL: It returns true,if the column value is null.
IS NOT NULL: It returns true,if the columns value is not null.
=>: It's a compare operator similar with “=” but not the same.It returns true even for the two null values.
(eg. null => null is legal)
IFNULL(): Specify two input parameters,if the first is null value then returns the second one.
It's similar with Oracle's NVL() function.

NULL并不意味著什么都沒有,我們要注意 NULL 跟 ''(空值)是兩個完全不一樣的值.MySQL中可以操作NULL值操作符主要有三個.

  • IS NULL
  • IS NOT NULL
  • => 太空船操作符,這個操作符很像=,select NULL=>NULL可以返回true,但是select NULL=NULL返回false.
  • IFNULL 一個函數.怎么使用自己查吧…反正我會了

Example

Null never returns true when comparing with any other values except null with “=>”.
NULL通過任一操作符與其它值比較都會得到NULL,除了=>.

(root@localhost mysql3306.sock)[zlm]>create table test_null(
    -> id int not null,
    -> name varchar(10)
    -> );
Query OK, 0 rows affected (0.02 sec)

(root@localhost mysql3306.sock)[zlm]>insert into test_null values(1,'zlm');
Query OK, 1 row affected (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>insert into test_null values(2,null);
Query OK, 1 row affected (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null;
+----+------+
| id | name |
+----+------+
|  1 | zlm  |
|  2 | NULL |
+----+------+
2 rows in set (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null where name=null;
Empty set (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null where name is null;
+----+------+
| id | name |
+----+------+
|  2 | NULL |
+----+------+
1 row in set (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null where name is not null;
+----+------+
| id | name |
+----+------+
|  1 | zlm  |
+----+------+
1 row in set (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null where null=null;
Empty set (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null where null>null;
Empty set (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select * from test_null where null=>null;
+----+------+
| id | name |
+----+------+
|  1 | zlm  |
|  2 | NULL |
+----+------+
2 rows in set (0.00 sec)

//null=>null always return true,it's equal to "where 1=1".

Null means “a missing and unknown value”.Let's see details below.
NULL代表一個不確定的值,就算是兩個NULL,它倆也不一定相等.(像不像C中未初始化的局部變量)

(root@localhost mysql3306.sock)[zlm]>SELECT 0 IS NULL, 0 IS NOT NULL, '' IS NULL, '' IS NOT NULL;
+-----------+---------------+------------+----------------+
| 0 IS NULL | 0 IS NOT NULL | '' IS NULL | '' IS NOT NULL |
+-----------+---------------+------------+----------------+
|         0 |             1 |          0 |              1 |
+-----------+---------------+------------+----------------+
1 row in set (0.00 sec)

//It's not equal to zero number or vacant string.
//In MySQL,0 means fasle,1 means true.

(root@localhost mysql3306.sock)[zlm]>SELECT 1 = NULL, 1 > NULL, 1  NULL, 1 > NULL;
+----------+-----------+----------+----------+
| 1 = NULL | 1 > NULL | 1  NULL | 1 > NULL |
+----------+-----------+----------+----------+
|     NULL |      NULL |     NULL |     NULL |
+----------+-----------+----------+----------+
1 row in set (0.00 sec)

//It cannot be compared with number.
//In MySQL,null means false,too.

It truns null as a result if any expression contains null value.
任何有返回值的表達式中有NULL參與時,都會得到另外一個NULL值.

(root@localhost mysql3306.sock)[zlm]>select ifnull(null,'First is null'),ifnull(null+10,'First is null'),ifnull(concat('abc',null),'First is null');
+------------------------------+---------------------------------+--------------------------------------------+
| ifnull(null,'First is null') | ifnull(null+10,'First is null') | ifnull(concat('abc',null),'First is null') |
+------------------------------+---------------------------------+--------------------------------------------+
| First is null                | First is null                   | First is null                              |
+------------------------------+---------------------------------+--------------------------------------------+
1 row in set (0.00 sec)

//null value needs to be disposed with ifnull() function,what usually causes sql statement more complex.
//As we all know,MySQL does not support funcion index.Therefore,indexes on the column may not be used.That's really worse.

It's diffrent when using count(*) count(null column).
使用count(*) 或者 count(null column)結果不同,count(null column)=count(*).

(root@localhost mysql3306.sock)[zlm]>select count(*),count(name) from test_null;
+----------+-------------+
| count(*) | count(name) |
+----------+-------------+
|        2 |           1 |
+----------+-------------+
1 row in set (0.00 sec)

//count(*) returns all rows ignore the null while count(name) returns the non-null rows in column "name".
//This will also leads to uncertainty if someone is unaware of the details above.

如果使用者對NULL屬性不熟悉,很容易統計出錯誤的結果.

When using distinct,group by,order by,all null values are considered as the same value.
雖然select NULL=NULL的結果為false,但是在我們使用distinct,group by,order by時,NULL又被認為是相同值.

(root@localhost mysql3306.sock)[zlm]>insert into test_null values(3,null);
Query OK, 1 row affected (0.00 sec)

(root@localhost mysql3306.sock)[zlm]>select distinct name from test_null;
+------+
| name |
+------+
| zlm  |
| NULL |
+------+
2 rows in set (0.00 sec)

//Two rows of null value returned one and the result became two.

(root@localhost mysql3306.sock)[zlm]>select name from test_null group by name;
+------+
| name |
+------+
| NULL |
| zlm  |
+------+
2 rows in set (0.00 sec)

//Two rows of null value were put into the same group.
//By default,group by will also sort the result(null row showed first).

(root@localhost mysql3306.sock)[zlm]>select id,name from test_null order by name;
+----+------+
| id | name |
+----+------+
|  2 | NULL |
|  3 | NULL |
|  1 | zlm  |
+----+------+
3 rows in set (0.00 sec)

//Three rows were sorted(two null rows showed first).

MySQL supports to use index on column which contains null value(what's different from oracle).
MySQL中支持在含有NULL值的列上使用索引,但是Oracle不支持.這就是我們平時所說的如果列上含有NULL那么將會使索引失效.
嚴格來說,這句話對與MySQL來說是不準確的.

(root@localhost mysql3306.sock)[sysbench]>show tables;
+--------------------+
| Tables_in_sysbench |
+--------------------+
| sbtest1            |
| sbtest10           |
| sbtest2            |
| sbtest3            |
| sbtest4            |
| sbtest5            |
| sbtest6            |
| sbtest7            |
| sbtest8            |
| sbtest9            |
+--------------------+
10 rows in set (0.00 sec)

(root@localhost mysql3306.sock)[sysbench]>show create table sbtest1\G
*************************** 1. row ***************************
       Table: sbtest1
Create Table: CREATE TABLE `sbtest1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `k` int(11) NOT NULL DEFAULT '0',
  `c` char(120) NOT NULL DEFAULT '',
  `pad` char(60) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`),
  KEY `k_1` (`k`)
) ENGINE=InnoDB AUTO_INCREMENT=100001 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

(root@localhost mysql3306.sock)[sysbench]>alter table sbtest1 modify k int null,modify c char(120) null,modify pad char(60) null;
Query OK, 0 rows affected (4.14 sec)
Records: 0  Duplicates: 0  Warnings: 0

(root@localhost mysql3306.sock)[sysbench]>insert into sbtest1 values(100001,null,null,null);
Query OK, 1 row affected (0.00 sec)

(root@localhost mysql3306.sock)[sysbench]>explain select id,k from sbtest1 where id=100001;
+----+-------------+---------+------------+-------+---------------+---------+---------+-------+------+----------+-------+
| id | select_type | table   | partitions | type  | possible_keys | key     | key_len | ref   | rows | filtered | Extra |
+----+-------------+---------+------------+-------+---------------+---------+---------+-------+------+----------+-------+
|  1 | SIMPLE      | sbtest1 | NULL       | const | PRIMARY       | PRIMARY | 4       | const |    1 |   100.00 | NULL  |
+----+-------------+---------+------------+-------+---------------+---------+---------+-------+------+----------+-------+
1 row in set, 1 warning (0.00 sec)

(root@localhost mysql3306.sock)[sysbench]>explain select id,k from sbtest1 where k is null;
+----+-------------+---------+------------+------+---------------+------+---------+-------+------+----------+--------------------------+
| id | select_type | table   | partitions | type | possible_keys | key  | key_len | ref   | rows | filtered | Extra                    |
+----+-------------+---------+------------+------+---------------+------+---------+-------+------+----------+--------------------------+
|  1 | SIMPLE      | sbtest1 | NULL       | ref  | k_1           | k_1  | 5       | const |    1 |   100.00 | Using where; Using index |
+----+-------------+---------+------------+------+---------------+------+---------+-------+------+----------+--------------------------+
1 row in set, 1 warning (0.00 sec)

//In the first query,the newly added row is retrieved by primary key.
//In the second query,the newly added row is retrieved by secondary key "k_1"
//It has been proved that indexes can be used on the columns which contain null value.
//column "k" is int datatype which occupies 4 bytes,but the value of "key_len" turn out to be 5.what's happed?Because null value needs 1 byte to store the null flag in the rows.

這個是我自己測試的例子.

mysql> select * from test_1;
+-----------+------+------+
| name      | code | id   |
+-----------+------+------+
| gaoyi     | wo   |    1 |
| gaoyi     | w    |    2 |
| chuzhong  | wo   |    3 |
| chuzhong  | w    |    4 |
| xiaoxue   | dd   |    5 |
| xiaoxue   | dfdf |    6 |
| sujianhui | su   |   99 |
| sujianhui | NULL |   99 |
+-----------+------+------+
8 rows in set (0.00 sec)

mysql> explain select * from test_1 where code is NULL;
+----+-------------+--------+------------+------+---------------+------------+---------+-------+------+----------+-----------------------+
| id | select_type | table  | partitions | type | possible_keys | key        | key_len | ref   | rows | filtered | Extra                 |
+----+-------------+--------+------------+------+---------------+------------+---------+-------+------+----------+-----------------------+
|  1 | SIMPLE      | test_1 | NULL       | ref  | index_code    | index_code | 161     | const |    1 |   100.00 | Using index condition |
+----+-------------+--------+------------+------+---------------+------------+---------+-------+------+----------+-----------------------+
1 row in set, 1 warning (0.00 sec)

mysql> explain select * from test_1 where code is not NULL;
+----+-------------+--------+------------+-------+---------------+------------+---------+------+------+----------+-----------------------+
| id | select_type | table  | partitions | type  | possible_keys | key        | key_len | ref  | rows | filtered | Extra                 |
+----+-------------+--------+------------+-------+---------------+------------+---------+------+------+----------+-----------------------+
|  1 | SIMPLE      | test_1 | NULL       | range | index_code    | index_code | 161     | NULL |    7 |   100.00 | Using index condition |
+----+-------------+--------+------------+-------+---------------+------------+---------+------+------+----------+-----------------------+
1 row in set, 1 warning (0.00 sec)

mysql> explain select * from test_1 where code='dd';
+----+-------------+--------+------------+------+---------------+------------+---------+-------+------+----------+-----------------------+
| id | select_type | table  | partitions | type | possible_keys | key        | key_len | ref   | rows | filtered | Extra                 |
+----+-------------+--------+------------+------+---------------+------------+---------+-------+------+----------+-----------------------+
|  1 | SIMPLE      | test_1 | NULL       | ref  | index_code    | index_code | 161     | const |    1 |   100.00 | Using index condition |
+----+-------------+--------+------------+------+---------------+------------+---------+-------+------+----------+-----------------------+
1 row in set, 1 warning (0.00 sec)

mysql> explain select * from test_1 where code like "dd%";
+----+-------------+--------+------------+-------+---------------+------------+---------+------+------+----------+-----------------------+
| id | select_type | table  | partitions | type  | possible_keys | key        | key_len | ref  | rows | filtered | Extra                 |
+----+-------------+--------+------------+-------+---------------+------------+---------+------+------+----------+-----------------------+
|  1 | SIMPLE      | test_1 | NULL       | range | index_code    | index_code | 161     | NULL |    1 |   100.00 | Using index condition |
+----+-------------+--------+------------+-------+---------------+------------+---------+------+------+----------+-----------------------+
1 row in set, 1 warning (0.00 sec)

Summary 總結

null value always leads to many uncertainties when disposing sql statement.It may cause bad performance accidentally.

列中使用NULL值容易引發不受控制的事情發生,有時候還會嚴重托慢系統的性能.

例如:

null value will not be estimated in aggregate function() which may cause inaccurate results.
對含有NULL值的列進行統計計算,eg. count(),max(),min(),結果并不符合我們的期望值.

null value will influence the behavior of the operations such as “distinct”,“group by”,“order by” which causes wrong sort.
干擾排序,分組,去重結果.

null value needs ifnull() function to do judgement which makes the program code more complex.
有的時候為了消除NULL帶來的技術債務,我們需要在SQL中使用IFNULL()來確保結果可控,但是這使程序變得復雜.
null value needs a extra 1 byte to store the null information in the rows.

NULL值并是占用原有的字段空間存儲,而是額外申請一個字節去標注,這個字段添加了NULL約束.(就像額外的標志位一樣)
As these above drawbacks,it's not recommended to define columns with default null.
We recommand to define “not null” on all columns and use zero number vacant string to substitute relevant data type of null.

根據以上缺點,我們并不推薦在列中設置NULL作為列的默認值,你可以使用NOT NULL消除默認設置,使用0或者''空字符串來代替NULL.

參考資料

 https://www.cnblogs.com/aaron8219/p/9259379.html

到此這篇關于MySQL為何不建議使用默認值為null列的文章就介紹到這了,更多相關MySQL默認值為null內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 方便快捷實現springboot 后端配置多個數據源、Mysql數據庫
  • MySQL DEFINER具體使用詳解
  • MySQL隔離級別和鎖機制的深入講解
  • django生產環境搭建(uWSGI+django+nginx+python+MySQL)
  • 淺析MySQL 主鍵使用數字還是uuid查詢快
  • MySQL之權限以及設計數據庫案例講解
  • Node-Red實現MySQL數據庫連接的方法
  • mysql之group by和having用法詳解

標簽:溫州 無錫 福州 阿里 定西 山西 揚州 三明

巨人網絡通訊聲明:本文標題《MySQL為何不建議使用默認值為null列》,本文關鍵詞  MySQL,為,何不,建議,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL為何不建議使用默認值為null列》相關的同類信息!
  • 本頁收集關于MySQL為何不建議使用默認值為null列的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    精品一区二区在线观看| 播五月开心婷婷综合| 国产伦精品一区二区三区在线观看 | |精品福利一区二区三区| 麻豆一区二区99久久久久| 99久久99久久免费精品蜜臀| 欧美电视剧免费观看| 亚洲妇熟xx妇色黄| 色综合网站在线| 国产精品视频在线看| 激情文学综合插| 欧美一区二区私人影院日本| 亚洲卡通欧美制服中文| 国产不卡高清在线观看视频| 日韩欧美国产高清| 日韩国产一二三区| 欧美性一级生活| 亚洲男人的天堂网| av午夜一区麻豆| 国产精品乱人伦| 国产麻豆视频一区二区| 2023国产精华国产精品| 蜜臀久久久久久久| 日韩午夜电影在线观看| 麻豆精品一区二区三区| 日韩一区二区三区在线观看 | 在线观看av一区| 国产精品伦一区二区三级视频| 国产在线精品一区二区三区不卡 | 国产精品自在在线| 日韩精品一区二区三区视频 | 午夜久久久久久久久久一区二区| 99精品视频一区二区| 中文字幕一区二区日韩精品绯色| 国产福利视频一区二区三区| 久久久久久久久久看片| 91一区二区在线| 亚洲综合久久av| 欧美久久久久久久久| 人人超碰91尤物精品国产| 欧美电影免费观看高清完整版在线观看| 日韩不卡一区二区| 久久综合色综合88| 成年人网站91| 亚洲综合在线免费观看| 欧美日韩精品免费观看视频| 蜜臀91精品一区二区三区 | 粉嫩一区二区三区性色av| 国产片一区二区| 91麻豆福利精品推荐| 亚洲国产精品麻豆| 欧美精品一区二区精品网| 国产成人午夜片在线观看高清观看| 国产精品久久午夜夜伦鲁鲁| 日本久久精品电影| 美女免费视频一区二区| 国产精品人成在线观看免费| 色av成人天堂桃色av| 蜜臀av亚洲一区中文字幕| 亚洲国产精品成人久久综合一区 | 99在线视频精品| 亚洲一区欧美一区| 精品精品欲导航| 91在线国产观看| 蜜桃视频第一区免费观看| 国产精品美女久久久久久2018 | 麻豆一区二区三区| 中文字幕免费在线观看视频一区| 欧美亚洲综合久久| 国产成人综合亚洲网站| 亚洲大片在线观看| 国产欧美精品国产国产专区 | 蜜臀a∨国产成人精品| 亚洲欧美日韩综合aⅴ视频| 欧美一区二区高清| 色一情一乱一乱一91av| 激情偷乱视频一区二区三区| 一个色在线综合| 国产欧美中文在线| 91精品国产综合久久婷婷香蕉 | 国产成人免费视频网站| 日韩综合小视频| 亚洲欧美在线视频观看| 欧美精品一区二区三区蜜臀| 欧美三级蜜桃2在线观看| 国产精品一区二区三区网站| 日韩va欧美va亚洲va久久| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 午夜国产精品一区| 中文字幕一区二区在线播放| 精品成人一区二区三区四区| 欧美日韩三级在线| 色婷婷综合中文久久一本| 国产99久久久国产精品免费看| 青青草成人在线观看| 亚洲图片一区二区| 伊人性伊人情综合网| 国产精品成人一区二区三区夜夜夜 | 久久精品男人天堂av| 欧美一区三区四区| 欧美性一级生活| 色视频成人在线观看免| 91小宝寻花一区二区三区| 粉嫩av一区二区三区在线播放| 久久精品二区亚洲w码| 天天做天天摸天天爽国产一区| 亚洲欧洲综合另类| 亚洲欧洲美洲综合色网| 国产精品视频一二三区| 国产日韩精品视频一区| 国产蜜臀av在线一区二区三区| 久久青草欧美一区二区三区| 欧美精品一区二区久久久| 337p日本欧洲亚洲大胆精品| 欧美大片一区二区| 久久久久国产精品麻豆| 久久蜜桃一区二区| 国产精品私人影院| 中文字幕一区免费在线观看 | 欧美午夜电影网| 欧美日韩国产精品自在自线| 欧美日韩精品一区二区三区四区 | 色天使色偷偷av一区二区| 日本电影欧美片| 欧美高清激情brazzers| 日韩欧美亚洲一区二区| www久久久久| 亚洲色图制服诱惑| 亚洲成人av一区二区| 三级影片在线观看欧美日韩一区二区 | 久久久精品日韩欧美| 欧美国产日韩a欧美在线观看| 国产精品久久久久久久久果冻传媒 | 欧美巨大另类极品videosbest| 91 com成人网| 国产欧美在线观看一区| 亚洲精品中文字幕在线观看| 首页综合国产亚洲丝袜| 韩国v欧美v日本v亚洲v| 99久久婷婷国产| 6080午夜不卡| 国产精品少妇自拍| 亚洲高清视频的网址| 国产在线看一区| 在线亚洲精品福利网址导航| 欧美一区二区三区公司| 国产精品美女久久久久久| 亚洲va在线va天堂| 国产精一区二区三区| 欧美视频在线一区二区三区| www激情久久| 亚洲第一电影网| 丰满白嫩尤物一区二区| 91精品一区二区三区在线观看| 欧美韩国日本一区| 日本一道高清亚洲日美韩| jiyouzz国产精品久久| 日韩美女在线视频 | 欧美日韩精品免费| 亚洲国产高清aⅴ视频| 婷婷六月综合亚洲| 色综合久久九月婷婷色综合| 精品日韩99亚洲| 亚洲国产精品久久不卡毛片| 成人伦理片在线| 日韩欧美一级在线播放| 亚洲一区二区三区精品在线| 国产成人在线观看免费网站| 欧美一区二区三区四区在线观看 | 亚洲欧美国产三级| 国产激情视频一区二区在线观看| 欧美精品乱码久久久久久按摩| 国产精品午夜在线观看| 国产在线一区观看| 日韩免费观看2025年上映的电影| 亚洲影院免费观看| www.色综合.com| 国产精品网站在线观看| 国产成人在线观看| 久久久久久久电影| 久久国产生活片100| 欧美理论电影在线| 性欧美大战久久久久久久久| 色嗨嗨av一区二区三区| 亚洲欧洲av在线| av在线一区二区三区| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产日韩一级二级三级| 激情六月婷婷久久| 久久影院视频免费| 国产精品18久久久久久久网站| xf在线a精品一区二区视频网站| 久久精品国产成人一区二区三区| 欧美一级片在线看| 免费人成网站在线观看欧美高清| 91精品婷婷国产综合久久| 免费在线观看不卡| 精品久久五月天| 国产精品一区在线| 中文字幕亚洲区|