mysql 不要統計null_淺談為什么Mysql數據庫盡量避免NULL

在Mysql中很多表都包含可為NULL(空值)的列,即使應用程序并不需要保存NULL也是如此,這是因為可為NULL是列的默認屬性。但我們常在一些Mysql性能優化的書或者一些博客中看到觀點:在數據列中,盡量不要用NULL 值,使用0,-1或者其他特殊標識替換NULL值,除非真的需要存儲NULL值,那到底是為什么?如果替換了會有什么好處?同時又有什么問題呢?那么就看下面:

(1)如果查詢中包含可為NULL的列,對Mysql來說更難優化,因為可為NULL的列使得索引,索引統計和值比較都更復雜。

(2)含NULL復合索引無效.

(3)可為NULL的列會使用更多的存儲空間,在Mysql中也需要特殊處理。

(4)當可為NULL的列被索引時,每個索引記錄需要一個額外的字節,在MyISAM里甚至還可能導致固定大小的索引(例如只有一個整數列的索引)變成可變大小的索引。

理由佐證

理由1不需要佐證

首先新建環境, sql語句如下

create table nulltesttable(

id int primary key,

name_not_null varchar(10) not null,

name_null varchar(10)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;

alter table nulltesttable add index idx_nulltesttable_name_not_null(name_not_null);

alter table nulltesttable add index idx_nulltesttable_name_null(name_null);

explain select * from nulltesttable where name_not_null='name'; // explain1

explain select * from nulltesttable where name_null='name'; // explain2

從sql 執行可以看出, explain1中 key_len = 32, explain2中 key_len = 33

explain1的32 由來: 10(字段長度) * 3(utf8字符編碼占用長度) + 2(varchar標識為變長占用長度)

explain2的32 由來: 10(字段長度) * 3(utf8字符編碼占用長度) + 2(varchar標識為變長占用長度) + 1(null標識位占用長度)

兩個字符串拼接, 如果包含null值, 則返回結果為null.

insert into nulltesttable(id,name_not_null,name_null) values(1,'one',null);

insert into nulltesttable(id,name_not_null,name_null) values(2,'two','three');

select concat(name_not_null,name_null) from nulltesttable where id = 1; -- out: null

select concat(name_not_null,name_null) from nulltesttable where id = 2; -- out: twothree

如果字段允許null值, 且這個字段被索引. 如下的查詢可能會返回不正確的結果

select * from nulltesttable where name_null <> 'three' -- out: null

select count(name_null) from nulltesttable -- out: 1

通常把可為NULL的列改為NOT NULL 帶來的性能提升比較小,所以(調優時)沒有必要首先在現有schema中查找并修改掉這種情況,除非確定這會導致問題。但是,如果計劃在列上建索引,就應該盡量避免設計成可為NULL的列。

當確實需要標識未知值時也不要害怕使用NULL。在一些場景中,使用NULL可能會比某個神奇常數更好。從特定類型的值域中選擇一個不可能的值,例如用-1代表一個未知數,可能導致代碼復雜的多,并容易引入BUG,還可能讓事情變得一團糟(注:Mysql會在索引中存儲NULL值,Oracle不會)。

當然也有例外,InnoDB使用單獨的位(bit)來存儲NULL值,所以對于稀疏數據(很多值位NULL,只有少數行的列有非NULL值)由很好的空間效率,這一點不適用于MyISAM。

所以任何的設計和考慮請注意關注實際需求

到此這篇關于淺談為什么Mysql數據庫盡量避免NULL的文章就介紹到這了,更多相關Mysql避免NULL內容請搜索站圈網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持站圈網!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/279146.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/279146.shtml
英文地址,請注明出處:http://en.pswp.cn/news/279146.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Swing學習1——總體概述

以下來自于JDK1.6 一、Swing學習我劃分為兩個方面&#xff1a; 一方面Swing的界面設計部分&#xff0c;包括相關組件類的繼承關系&#xff0c;組件的功能用途&#xff0c;布局管理&#xff1b; 1.首先繼承關系上自上而下為 java.lang.Object java.awt.Component java.awt.Conta…

裝飾設計模式和例題

文件復制程序&#xff1a; 將一個文件復制一份出來&#xff0c;實現方法很簡單&#xff0c;使用FileInputStream讀取文件內容&#xff0c;然后使用FileOutputStream寫入另一個文件&#xff0c;利用read方法的返回值作為while循環的條件&#xff0c;進行一邊讀一邊寫。 代碼示例…

mysql操作手冊我_MySQL使用指南一

我將MySQL常用指令整理出來分享給大家。1. 列出所有數據庫mysql> show databases;2. 創建數據庫mysql> create databases MyStorage;3. 打開數據庫mysql> use MyStorage;4. 創建表mysql> create table Storage-> (-> id int,-> name varchar(50),-> pr…

谷歌地圖將很快顯示電動汽車充電站

If you’re out on the road in the future and find your electric vehicle is in dire need of a charge, you’ll soon be able to look to Google Maps for help finding a charging station. 如果您將來出門在外&#xff0c;并且發現您的電動汽車急需充電&#xff0c;那么…

JS4

1. js的本質就是處理數據。數據來自于后臺的數據庫。 所以變量就起到一個臨時存儲數據的作用。 ECMAScript制定了js的數據類型。 數據類型有哪些&#xff1f; 字符串 String數字 Number布爾 BooleanNull 空Undefined Object 對象Array 數組 json function …

ovirt官方安裝文檔 第三章

第3章&#xff1a;安裝oVirt 安裝oVirt引擎包 在您可以配置和使用oVirt引擎之前&#xff0c;您必須安裝 rhevm 包和依賴關系。 安裝oVirt引擎包 在開始安裝oVirt之前&#xff0c;添加官方倉庫&#xff1a; # yum install http://resources.ovirt.org/pub/yum-repo/ovirt-releas…

mysql獲取查詢策略語句_MySQL數據庫查詢性能優化策略

優化查詢使用Explain語句分析查詢語句Explain 用來分析 SELECT 查詢語句&#xff0c;開發人員可以通過分析 Explain 結果來優化查詢語句。通過對查詢語句的分析,可以了解查詢語句的執行情況,找出查詢語句執行的瓶頸,從而優化查詢語句.使用索引查詢MySql中提高性能的一個最有效的…

松弛變量可以為負嗎_如何為松弛安裝(非官方)暗模式

松弛變量可以為負嗎Slack still doesn’t have a dark mode. They have dark themes, but those only let you customize the sidebar colors, leaving the main window white. With the release of system-wide dark modes on macOS Mojave and Windows 10, Slack feels very …

如何使用系統自帶的日志轉儲功能logroate.存放應用日志

Linux日志服務介紹 &#xff11;. 在Linux系統&#xff0c;大部分日志都是由syslog日志服務驅動和管理的 syslog服務由兩個重要的配置文件控制管理&#xff0c;分別是/etc/syslog.conf主配置文件和/etc/sysconfig/syslog輔助 配置文件&#xff0c; /etc/init.d/syslog是啟動腳本…

shell 多行注釋

:<<BLOCK 中間為要注釋的內容 BLOCK轉載于:https://www.cnblogs.com/S--S/p/9817660.html

natcat for mysql_用Navicat for mysql連接mysql報錯1251-解決辦法

TP框架連接mongodb報錯及解決辦法mongodb版本3.4.7 1.認證錯誤:Failed to connect to: localhost:27017: Authentication failed on database test ...Loadrunner參數化連接oracle、mysql數據源報錯及解決辦法Loadrunner參數化連接oracle.mysql數據源報錯及解決辦法 (本人系統是…

如何在Mac上設置FaceTime

FaceTime is Apple’s built-in video and audio calling app. It pairs with your iPhone and allows you to make phone calls on macOS. FaceTime是Apple的內置視頻和音頻通話應用程序。 它可以與iPhone配對使用&#xff0c;并允許您在macOS上撥打電話。 You don’t need an…

移動視頻技術

在語音通信已得到教育、醫療、社交、電子商務等多個領域的移動應用和充分發展的今天&#xff0c;人們已不滿足于僅依靠語音電話來傳達信息。開發者都需要結合自身業務場景在其產品中嵌入語音聊天、視頻通話、語音對講等實時通話功能。但較高的技術門檻和開發成本成為普通開發者…

hashlib 模塊用來進行hash

hashlib的基本概述&#xff1a; python中的 hashlib 模塊用來進行hash 或者md5加密&#xff0c;而且這種加密是不可逆的&#xff0c;所以這種算法又被稱為摘要算法&#xff0c; 其支持Opennssl庫提供的所有算法&#xff0c;包括 md5、sha1、sha224、sha256、sha512 等。 hash是…

在Ubuntu 11.10中將窗口按鈕移回右側

As of Ubuntu 10.04, the minimize, maximize, and close buttons on all windows were moved to the left side and the system menu was removed. Prior to version 11.10, you could use several methods to restore the original button arrangement. 從Ubuntu 10.04開始&a…

java測試開發_測試開發系類之Java常用知識點

測試需要的兩門語言&#xff1a;Java&#xff0c;Python測試開發&#xff1a;開發測試腳本->開發測試框架Java需要掌握內容&#xff1a;基礎語法、Java面向對象相關概念、Java常用類、基礎測試框架Java常用類&#xff1a;IO相關類&#xff0c;包括&#xff1a;字節流InputSt…

kafka 服務端消費者和生產者的配置

在kafka的安裝目錄下&#xff0c;config目錄下有個名字叫做producer.properties的配置文件 #指定kafka節點列表&#xff0c;用于獲取metadata&#xff0c;不必全部指定 #需要kafka的服務器地址&#xff0c;來獲取每一個topic的分片數等元數據信息。 metadata.broker.listkafka0…

如何在Windows 10上使用觸摸板手勢

If you’ve used a touchpad in Windows 10, you’re no doubt aware of the basic single-finger tapping and two-finger scrolling gestures. Windows 10 also packs in some additional gestures you might not have tried. 如果您在Windows 10中使用了觸摸板&#xff0c;那…

java全棧開發工程師_談談我對Java(J2EE)全棧工程師的理解

很多剛從事Java開發的同學都有一個疑問&#xff0c;到底是向全棧式程序員方向發展還是做精通某種技術的專才&#xff1f;對于這個問題也是見仁見智。 在給出我的觀點之前&#xff0c;我們先來分析一下全棧工程師的種類和專才的種類 &#xff0c;之后關于這個問題的答案就很清楚…

多網卡命名規則

使用iptables做nat路由&#xff0c;需要幾張網卡&#xff0c;以下命令很有用 1.首先你要先確認你系統加載的網卡&#xff0c;lspci|grep -i eth,如果出現unknow情況或者未識別&#xff0c;最好換網卡&#xff0c;或者是驅動沒有加載&#xff0c;需要到/lib/modules的子目錄driv…