MySQL Ruler mysql 日常開發規範

来源:https://www.cnblogs.com/houbbBlogs/p/18126113
-Advertisement-
Play Games

拓展閱讀 MySQL View MySQL truncate table 與 delete 清空表的區別和坑 MySQL Ruler mysql 日常開發規範 MySQL datetime timestamp 以及如何自動更新,如何實現範圍查詢 MySQL 06 mysql 如何實現類似 oracl ...


拓展閱讀

MySQL View

MySQL truncate table 與 delete 清空表的區別和坑

MySQL Ruler mysql 日常開發規範

MySQL datetime timestamp 以及如何自動更新,如何實現範圍查詢

MySQL 06 mysql 如何實現類似 oracle 的 merge into

MySQL 05 MySQL入門教程(MySQL tutorial book)

MySQL 04- EMOJI 表情與 UTF8MB4 的故事

MySQL Expression 1 of ORDER BY clause is not in SELECT list,references column

MySQL Ruler

寫在前面:

一、為何寫

為了自己以後的腳本編寫或者是為團隊公司提供一個可以達成共識的標準。

二、怎麼定規範

簡潔明瞭。根據實際業務可以進行調整。每一個規定儘量描述清楚緣由。規範必須是不斷變化的,量體裁衣。

三、參考

《架構師之路》中有提及一些資料庫軍規。可以提供參考。

四、使用

解讀比規則本身更重要。

規範草案

基礎規範

適用於所有。(database, table, column)

1、必須有中文解釋

可以解釋到任何一個程式員(包括黑客)看到註釋後立刻理解其中的含義。而不是推敲其中的意思。為了保證這一點,衍生了第二條。

2、儘量使用英文,禁止中英文混用命名。

比如你看到了 zhrmghg 這個欄位然後覺得很深奧,後來問命名者告訴你是中華人民共和國的簡拼啊,你看不出來啊。。。

3、命名禁止出現大寫字母, 禁止出現_以外的字元。

必須保證命名規則轉換後可以符合比如駝峰命名。

4、禁止使用數字。使用英文單詞替代。

舉個例子 email_1, 那麼請重命名為email_one。相信你可寫出0-99的英文單詞。避免,分不清l1, 分不清o0。

5、禁止使用雙引號對名稱引用, 避免大小寫敏感。

如果需要單詞間空格, 替換為下劃線。

6、所有的命名儘量指出欄位的業務含義。

如此之難,以至於想將這一條刪除。

資料庫規範

1、統一使用 UTF-8 編碼

無需轉碼,無亂碼風險。

2、資料庫命名與系統名稱保持一致。且必須滿足基礎規範。

比如項目名稱blog-service, 對應資料庫名稱 blog_service

表規範

1、如果是 MySQL, 請使用 InnoDB 引擎

支持事務。其他不吹不黑。

2、必須有主鍵。

如BIGINT(20)自增的ID, 有利於表的管理。但是這個ID未必是你的唯一約束主鍵。

3、禁止使用外鍵。

所有的關聯使用應用程式去保證。

4、表名稱應統一使用t_開頭。

可以與普通的類區分開。當然這一點不強求。(很多公司做不到)

列規範

1、禁止列名使用 col等毫無意義的作為首碼/尾碼。

不要把名稱浪費在無用的事情上。

2、主鍵命名統一為id, 當然你也可以使其不包含任何業務含義。

不多說。

3、表中一般會包含2個欄位,創建時間和更新時間。請自行統一約定。

date 一般指日期, time 指時間。你可以約定為 created_timeupdated_time。保證所有的 表統一。不要亂改名字。

4、所有的欄位都儘量設定為 NOT NULL

這一點根據業務而定。其實 null 不節約任何空間且會導致查詢性能優化變得困難。

5、禁止使用 TEXT、BLOB 此類較大的欄位

存放他的URL,對應的內容放在文件伺服器中。

索引規範

1、單表索引不易過多。(5個以內為佳)

2、組合索引,區分度大的放在前面。

利於數據的快速過濾。

3、索引命名如下:

  • pk 主鍵 (primary key)

  • uk 唯一鍵 (unique key)

  • nk 普通索引 (normal key)

以上命名方式為首碼。你會說為什麼不寫英文全拼啊 ? 不現實,總會有人寫錯。

SQL 使用規範

1、禁止使用 SELECT *, 必須指定需要查詢的欄位。

2、禁止使用 INSERT INTO t_xxx VALUES (XXX), 必須明確指定插入的列屬性

3、禁止全表掃描

可以看下 索引不工作的case, 實在無法避免可以和前端結合。比如查詢必須指定某一區分度很大的欄位才能查詢。

4、儘量不使用 JOIN

這一點很多人難以接受。處於性能無可厚非的規則。但是如果性能要求沒有這麼高,資源又有限,可不必遵循。


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

-Advertisement-
Play Games
更多相關文章
  • Spring Boot啟動時的初始化可通過監聽事件、實現介面及使用註解實現等方式,每種方式對應不同場景,確保應用啟動時關鍵邏輯執行。 ...
  • 前言 請各大網友尊重本人原創知識分享,謹記本人博客:南國以南i、 準備工作:現有一個User類、Student 類和Ticket類,加入相關依賴 @Data public class User { /** * id */ private Integer id; /** * 姓名 */ private ...
  • 使用場景 RequiredActionProvider,它是在認證過程中,需要當前登錄的用戶執行個性化的動作;當用戶符合條件,就被執行RequiredActionProvider對作,當RequiredActionProvider沒有正常提交(context.success())之前,當前用戶仍然是 ...
  • 左手編程,右手年華。大家好,我是一點,關註我,帶你走入編程的世界。 公眾號:一點sir,關註領取python編程資料 在數字媒體的時代,視頻處理成為了一項重要的技能。無論是剪輯、轉碼、還是添加特效,都需要強大的工具來處理視頻素材。Python作為一門功能強大的編程語言,在視頻處理領域也有著廣泛的應用 ...
  • 單線程下的單例模式: public class Singleton { private static Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == ...
  • 獲取數組的大小 要獲取數組的大小,可以使用 sizeof() 運算符: 示例 int myNumbers[5] = {10, 20, 30, 40, 50}; cout << sizeof(myNumbers); 結果: 20 為什麼結果顯示為 20 而不是 5,當數組包含 5 個元素時? 這是因為 ...
  • 提供者目錄 Provider Authenticator BaseDirectGrantAuthenticator AbstractFormAuthenticator AbstractUsernameFormAuthenticator RequiredActionProvider FormActio ...
  • 強制等待 即sleep()方法,由python中的time模塊提供,強制讓代碼等待xxx時間,無論前面的代碼是否執行完成或者還未完成,都必須等待設定的時間。 示例代碼如下: # coding = utf-8 from selenium import webdriver from time impor ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...