用了這麼多年MySql,這些好習慣你用過哪些

来源:https://www.cnblogs.com/peyshine/archive/2020/05/21/12928825.html
-Advertisement-
Play Games

一:新建表和欄位建議: 1.所有數據表和欄位要有清晰的註釋,欄位說明 說明:不管是創建者還是其他開發或者後續維護者都能清楚知道數據表和欄位定義的含義 2.表名、欄位名使用小寫字母或數字,禁止出現數字開頭 說明:MySQL在Windows下不區分大小寫,但在Linux下預設是區分大小寫,為了避免出現不 ...


一:新建表和欄位建議:

1.所有數據表和欄位要有清晰的註釋,欄位說明   說明:不管是創建者還是其他開發或者後續維護者都能清楚知道數據表和欄位定義的含義   2.表名、欄位名使用小寫字母或數字,禁止出現數字開頭   說明:MySQL在Windows下不區分大小寫,但在Linux下預設是區分大小寫,為了避免出現不必要的麻煩,統一使用小寫   3.每個列都設置為not null(如果列為BLOB/TEXT類型的,則這個列不能設置為NOT NULL),且定義預設值   說明:3.1:NOT IN、!= 等負向條件查詢在有 NULL 值的情況下返回非空行的結果集   3.2:使用 concat 函數拼接時,首先要對各個欄位進行非 NULL 判斷,否則只要任何一個欄位為空都會造成拼接的結果為 NULL   3.3:當用count函數進行統計時,NULL 列不會計入統計   3.4:因為NULL的列使得索引,索引統計和值比較都更複雜,可為NULL的列會使用更多的存儲空間,在mysql里也需要特殊處理,當可為NULL的列被索引時,每個索引記錄需要一個額外的位元組,如果計劃在列上建索引,應該避免將列設計為NULL。   4.每個表有自增列id且為主鍵,使用無符號類型unsigned,不作業務邏輯使用   說明:4.1:避免存儲負值,且擴大了表示範圍   4.2:如果使用非自增主鍵(如果身份證號或學號等),由於每次插入主鍵的值近似於隨機,因此每次新紀錄都要被插到現有索引頁得中間某個位置,此時MySQL不得不為了將新記錄插到合適位置而移動數據,甚至目標頁面可能已經被回寫到磁碟上而從緩存中清掉,此時又要從磁碟上讀回來,這增加了很多開銷,同時頻繁的移動、分頁操作造成了大量的碎片,得到了不夠緊湊的索引結構,後續不得不通過OPTIMIZE TABLE來重建表並優化填充頁面   5.表達是否概念的列,使用is_xxx的方式命名,數據類型使用unsigned tinyint(1表示是,0表示否)   例如:is_valid,1.表示有效 0.表示無效   6.禁止使用mysql保留字,例如desc,range,match,action,add,alter,all..等等   更多保留字可以參考mysql官方文檔說明:https://dev.mysql.com/doc/refman/5.7/en/keywords.html   7.varchar是可變長字元串,不預先分配存儲空間,長度不要超過5000,如果存儲長度大於此值,定義欄位類型為text,獨立出來一張表,用主鍵來對應,避免影響其它欄位索引效率   8.單表行數 超過500萬行或者表單容量超過2GB,才推薦進行分庫分表   9.命令規範:主鍵索引名以pk_欄位名;唯一索引名uk_欄位名;普通索引名idx_欄位名;臨時表則以tmp為首碼   10.小數類型為decimal,禁止使用float和double   說明:float和double的存儲的時候,存在精度損失的問題,很可能在值的比較時,得到不正確的結果。如果存儲的數據範圍超過decimal的範圍,建議將數據拆成整數和小數分開存儲   11.欄位允許適當冗餘,以提高查詢性能,冗餘欄位應遵循:1)不是頻繁修改的欄位。2)不是varchar超長欄位,更不能是text欄位。   12.InnoDB和MyISAM存儲引擎表,索引類型選擇BTREE;MEMORY表可以根據需要選擇HASH或者BTREE類型索引。   13.在建立索引時,多考慮建立聯合索引,並把區分度最高的欄位放在最前面,這樣可以更高效檢索數據   14.合適的字元存儲長度,不但節約資料庫表空間、節約索引存儲,更重要的是提升檢索速度  
對象 年齡區間 類型 位元組 表示範圍
150之內 unsigned tinyint 1 無符號:0-255
數百歲 unsigned smallint 2 無符號:0-65535
恐龍化石 數千年 unsigned int 4 無符號:0-42.9億
太陽 約50億年 unsigned bigint 8 無符號:0-約10的19次方
 

二:增刪改查好習慣

  1.SELECT語句指定具體欄位名稱,禁止寫成*,select *會將不該讀的數據也從MySQL里讀出來,造成不必要的帶寬壓力   2.分頁查詢,當limit起點較高時,可先用過濾條件進行過濾。如select f1,f2,f3 from table1 limit 20000,20;優化為: select f1,f2,f3 from table1 where id>20000 limit 20   3.where條件里等號左右欄位類型一致,否則無法利用索引   4.在多表join中,儘量選取結果集較小的表作為驅動表,來join其他表   5.插入列列表與值列表個數相同,上面二者的個數需要相同,如果沒有指定列列表,則值列表長度要與表列數相同。   6.更新刪除影響行數不要太大,如果太大,進行細粒度拆分   7.更新,刪除語句記得隨手寫好where條件(你想刪庫嗎?哈哈)  

歡迎大家補充,一起建立更優雅的數據規範


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上一篇寫了Redis複製功能的簡單應用,下麵我們看下Redis複製功能的實現過程。下麵基本上是理論部分,枯燥乏味,但希望大家能看看,畢竟知識不都是感興趣的.耐得住寂寞,經得起誘惑,方能守得住繁華 ~.~舊版複製功能的實現 Redis的複製功能分為同步和命令傳播兩個操作: 1、同步操作用於將從伺服器的 ...
  • 本文來源於公眾號【胖滾豬學編程】,轉載請註明出處! 關於數據中台的概念和架構,我們在 "大白話 六問數據中台" 和 "數據中台全景架構及模塊解析!一文入門中台架構師!" 兩篇文章中都說明白了。從這一篇文章開始分享中台落地實戰。 其實無論是數據中台還是數據平臺,數據無疑都是核心中的核心,所以閉著眼睛想 ...
  • 腳本: /* 說明:sql server如何通過pivot對數據進行行列轉換 腳本來源:https://www.cnblogs.com/zhang502219048/p/12933347.html */ create table #t ( [員工工號] nvarchar(50), [員工姓名] nv ...
  • 雖然現在使用哨兵+主從的方式比較少了,但通過理解 Redis 哨兵,我們能獲得更深入的分散式的知識。 https://redis.io/topics/sentinel sentinel基本配置 sentinel的作用: 1、監控 2、通知 3、自動故障轉移 (1.投票決策master是否掛了,如果投 ...
  • 首先我的伺服器是Centos7.6。低於7版本的小伙伴不可照搬。 我選擇的是使用rpm的方式進行安裝,比較方便。 "kudu安裝包下載地址" ctrl+f 查找kudu,這6個rpm包都要下載下來,推薦使用迅雷下載 在下載的時候我們還需要做一些準備工作。執行以下命令,安裝必備的包。 沒有安裝ntp的 ...
  • Redis的主從複製是如何工作的?如何在同步數據的同時,還保持著高性能,你瞭解嗎? https://redis.io/topics/replication 註意以下基於 redis 5 最新版本, 名詞和配置項已經被官方改為 ,其實是一個東西,都指從節點。 主從複製的基本流程 主 與 從 複製的基本 ...
  • NTP時鐘伺服器(NTP校時伺服器)日常維護與實施 NTP時鐘伺服器(NTP校時伺服器)日常維護與實施 京準電子科技VX——ahjzsz 京準電子科技有限公司主營ntp網路時鐘伺服器,時鐘同步產品, 產品正在國內外各行業近萬個現場穩定運行,現就設備安裝、日常維護及解決方案做下總結。 一、NTP網路時 ...
  • oracle11g,安裝完成之後直接使用,今天用PLSQL鏈接突然報錯,報錯代碼為:ORA-12514:監聽程式當前無法識別連接描述符中請求的服務。網上查了這種異常的解決辦法,特在此記錄。 出現該問題一般有兩種情況。 第一種是在你安裝完之後未配置監聽(在此我暫時忘記安裝完之後有沒有配置監聽); 第二 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...