數據庫命名規范
1 目的
規范數據庫各種對象的命名規則。
2 數據庫命名原則
2.1 數據文件
如果數據庫采用文件系統,而不是裸設備,約定下列命名規則:
1)數據文件以表空間名為開始,以.dbf為結尾,全部采用小寫英文字母加數字命名。如該表空間有多個數據文件,則從第2個數據文件開始,在表空間名後加_。
例:對system表空間的數據文件:system.dbf,system_2.dbf
2)對oracle數據庫的控制文件,用control.ctl來表示。如control01.ctl,control02.ctl。
3)對oracle數據庫的日志文件,在線日志文件用redo<組名><文件序列名>.dbf來表示。其中組名和文件序列名均用2位數字來表示。如第一組的兩個文件表示位redo0101.dbf和redo0102.dbf。歸檔日志用arch_%t_%s.arc來表示。其中%t和%s均為oracle約定的變量。
2.2 表空間
2.2.1 數據庫系統表空間
數據庫系統表空間包括system表空間,臨時表空間,回滾段的表空間。約定下列命名規則:
1)system表空間由數據庫直接限定,不能進行修改。
2)臨時表空間用temp來表示。如果有多個臨時表空間,從第2個臨時表空間開始,在temp後面加來表示。
3)回滾段表空間用undotbs來表示。如果有多個回滾段表空間,從第2個回滾段表空間開始,在undotbs後面加來表示。
2.2.2 數據庫的用戶表空間
數據庫的用戶表空間用ts_<表空間名>來表示。其中,表空間名分為:
1)數據空間:對於用戶的缺省表空間,用default來表示。對於其他的表空間,根據存放在表空間上的表的類別來表示。如放代碼的表,用code來表示。放客戶資料的表,用customer來表示。盡量用一個表空間來存放該類的表。如果某表特別大,可考慮單獨使用一個表空間。
2)索引空間:在相應的數據表空間的名字前加ind_。如對用戶缺省表空間的索引空間,用ts_ind_default來表示。對代碼表的索引表空間,用ts_ind_code來表示。
2.3 表
數據庫表的命名采用如下規則:
1)表名用T_開頭,表名長度不能超過30個字符,表名中含有單詞全部采用單數形式,單詞要大寫。
2)多個單詞間用下劃線(_)進行連接。若庫中有多個系統,表名采用系統名稱+單詞或多個單詞,系統名是開發系統的縮寫,如VNET。
3)表中含有的單詞建議用完整的單詞。如果導致表名長度超過30個字符,則從最後一個單詞開始,依次向前采用該單詞的縮寫。(如果沒有約定的縮寫,則采用該單詞前4個字母來表示)。
數據庫表的字段命名采用如下規則:
1)數據庫字段名全部采用小寫英文單詞,單詞之間用”_”隔開。字段長度不能超過30個字符。
2)如果該字段是代碼,則在單詞後加_id。
3)如果該字段表示的是時間,則使用_time為後綴。
2.4 視圖
數據庫視圖的命名采用如下規則:
1)視圖名用V_開頭,視圖名長度不能超過30個字符。視圖名用大寫的英文單詞來表示。
2)視圖由幾個表產生就用下劃線(_)連接幾個表的名,如果表過多可以將表名適當簡化,但一定要列出所有表名。
2.5 序列
數據庫序列的命名采用如下規則:
序列名用seq_開頭,後面跟使用該序列的字段名。如果有幾個字段用同一個序列,用下劃線(_)連接幾個字段的名稱。如果不同表中相同的字段名需要使用不同的序列,則在字段名後加表的特征,用下劃線(_)連接。序列名長度不能超過30個字符。序列名用小寫的英文單詞來表示。
2.6 存儲過程
存儲過程的命名采用如下規則:
存儲過程名用Pr_開頭,存儲過程名長度不能超過30個字符。存儲過程名用小寫的英文單詞來表示。
2.7 函數
函數的命名采用如下規則:
函數名用Fu_開頭,函數名長度不能超過30個字符。函數名用小寫的英文單詞來表示。
2.8 觸發器
觸發器的命名采用如下規則:
觸發器名用Tr_開頭,觸發器名長度不能超過30個字符。觸發器名用小寫的英文單詞來表示。
2.9 主鍵
主鍵的命名采用如下規則:
主鍵名用pk_開頭,後面跟該主鍵所在的表名。主鍵名長度不能超過30個字符。如果過長,可對表名進行縮寫。縮寫規則同表名的縮寫規則。主鍵名用小寫的英文單詞來表示。
2.10 外鍵
外鍵的命名采用如下規則:
外鍵名用fk_開頭,後面跟該外鍵所在的表名和對應的主表名(不含t_)。子表名和父表名自己用下劃線(_)分隔。外鍵名長度不能超過30個字符。如果過長,可對表名進行縮寫。縮寫規則同表名的縮寫規則。外鍵名用小寫的英文單詞來表示。
2.11 索引
索引的命名采用如下規則:
1)索引名用小寫的英文字母和數字表示。索引名的長度不能超過30個字符。
2)主鍵對應的索引和主鍵同名。
3)每類索引都用_結束。
4)唯一性索引用uni_開頭,後面跟表名。一般性索引用ind_開頭,後面跟表名。
5)如果索引長度過長,可對表名進行縮寫。縮寫規則同表名的縮寫規則。