日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:222日期:2023-10-17 19:27:06

通常能聽到的答案是使用了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 explicitlywhen creating the table.Many programmers like to define columns by defaultbecause of the conveniences(reducing the judgement code of nullibility) what consequentlycause 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 sbtest1G*************************** 1. row *************************** Table: sbtest1Create 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=utf81 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內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久在线91| 国产精品调教视频| 动漫av一区| 久久av影院| 日韩精品久久久久久| 久久高清国产| 亚洲一区国产| 日韩精品视频网| 亚洲三级国产| 美国三级日本三级久久99| 欧美日韩一区二区三区不卡视频 | 亚洲精品亚洲人成在线观看| 日韩午夜精品| 肉色欧美久久久久久久免费看| 精品欧美日韩精品| 精品日韩一区| 麻豆视频在线看| 久久久夜精品| 好吊日精品视频| 亚洲视频国产精品| 欧美一区激情| 精品欧美视频| 国产综合亚洲精品一区二| 尹人成人综合网| 亚洲精品麻豆| 国产欧美亚洲一区| 精品国产一区二区三区2021| 91视频久久| 日韩欧美一区免费| 欧美在线影院| 午夜性色一区二区三区免费视频| 欧美日韩一区二区高清| 精品国产午夜| 图片区亚洲欧美小说区| 免费欧美在线视频| 国产精品一区二区99| 国产麻豆精品| 电影亚洲精品噜噜在线观看| 欧美综合二区| 美女久久久久久 | 久久精品免视看国产成人| 高清日韩欧美| 91久久在线| 国产区精品区| 免费高清在线一区| 久久中文字幕一区二区| 欧美日韩第一| 国产一区 二区| se01亚洲视频 | 精品国产亚洲一区二区在线观看| 精品日韩视频| 日本不卡视频在线观看| 国产精品毛片久久| 中文字幕一区二区三区四区久久| 乱一区二区av| 日韩午夜在线| 欧美日韩视频免费看| 福利一区二区免费视频| 男人的天堂久久精品| 成人欧美一区二区三区的电影| 激情综合网站| 亚洲成人三区| 一区福利视频| 蜜臀久久久久久久| 欧产日产国产精品视频| 99久久亚洲精品蜜臀| 99综合视频| 精品中文字幕一区二区三区四区| 私拍精品福利视频在线一区| 色黄视频在线观看| 亚洲欧洲日韩| 精品美女视频 | 久久一级电影| 欧美va天堂在线| 亚洲小说春色综合另类电影| 国产精品久久久久久久久久妞妞| 欧美日韩国产精品一区二区亚洲| 日本aⅴ免费视频一区二区三区| 99精品小视频| 五月亚洲婷婷 | 日韩在线高清| 免费看欧美美女黄的网站| 不卡专区在线| 日韩精品一级中文字幕精品视频免费观看 | 日韩福利视频导航| 天海翼亚洲一区二区三区| 麻豆精品视频在线观看| 日韩精品一二三区| 国产美女高潮在线| 国产精品亚洲欧美日韩一区在线| 视频福利一区| 老色鬼精品视频在线观看播放| 91超碰国产精品| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲天堂av影院| 日韩精品欧美大片| 好吊视频一区二区三区四区| 麻豆国产精品一区二区三区| 日本不卡一区二区| 91精品啪在线观看国产18| 国产一区二区三区四区大秀| 亚洲专区在线| 国产91精品对白在线播放| 日韩av一区二区三区四区| 黑森林国产精品av| 久久久久九九精品影院| 欧美专区18| 好吊日精品视频| 91欧美在线| 国产精品v日韩精品v欧美精品网站| 免费视频久久| 午夜欧美理论片| 超碰99在线| 四虎成人av| 欧美激情一区| 日韩欧美精品一区二区综合视频| 国内一区二区三区| 国产日韩欧美一区在线| 亚洲欧美不卡| 亚洲欧洲一区| 日韩黄色大片| 欧洲一级精品| 一二三区精品| 国产一区导航| 精品91福利视频| 麻豆精品在线视频| 91精品国产自产观看在线| 男女男精品视频网| 欧美日韩亚洲一区| 色综合视频一区二区三区日韩| 亚洲欧洲一区| 久久蜜桃精品| 色爱综合av| 欧美另类专区| 欧美日一区二区在线观看| 久久国产精品免费精品3p| 香蕉成人久久| 97精品在线| 国产九一精品| 亚洲一区二区小说| 中文日韩欧美| 国产视频一区三区| 国产一区二区三区探花| 国产精品v亚洲精品v日韩精品| 69精品国产久热在线观看| 色综合视频一区二区三区日韩| 欧美日韩亚洲在线观看| 高清不卡一区| 国产精品蜜芽在线观看| 久久精品国产成人一区二区三区| 国产精品亚洲一区二区在线观看 | 97精品国产一区二区三区 | 日韩精品久久理论片| 97久久超碰| 亚洲一区av| 国产精品宾馆| 国产欧美日韩精品一区二区三区| 麻豆视频一区| 久久精品三级| 欧美搞黄网站| 性欧美长视频| 欧美日韩18| 国产精品115| 精品免费av在线| 亚洲视频www| 欧美日韩午夜电影网| 91精品国产自产在线丝袜啪| 精品99在线| 99久久婷婷| 日韩av不卡一区二区| 国产精品久久| 久久美女精品| 中文字幕亚洲影视| 精品久久在线| 日韩黄色大片网站| 在线观看亚洲精品福利片| 日韩av中文在线观看| 丁香六月综合| 国产麻豆综合| 你懂的国产精品永久在线| 精品国产亚洲日本| 性欧美精品高清| 欧美日韩一区二区三区在线电影| 欧美日韩免费看片| 丝袜亚洲精品中文字幕一区| 国产精品久久久久久久久久久久久久久| 精品国产一区二区三区噜噜噜| 久久一级电影| 天堂俺去俺来也www久久婷婷| 日韩理论视频| 热久久免费视频| 麻豆精品在线| 亚洲激情欧美| 久久久91麻豆精品国产一区| 成人羞羞在线观看网站| 亚洲日本国产| 成人午夜在线| 日韩精品1区2区3区| 国产黄大片在线观看| 中文字幕成人|