数据库对象命名

基本对象命名:

对象名称前缀举例
表(Table)Student
字段(Column)Title
视图(View)vvActivity
存储过程(Stored procedure)prprDelOrder
触发器(Trigger)trtrOrder_D
索引(Index)ix_ix_CustomerID
主键(Primary key)pk_pk_Admin
外键(Foreign key)fk_fk_Order_OrderType
Check 约束(Check Constraint)ck_ck_TableColumn
Unique 约束uq_uq_TableColumn
用户定义数据类型(User-defined data type)udtudtPhone
用户定义函数(User-defined function)fnfnDueDate

有关数据库的设计:

1. 如果要写代码来确保表中的行都是唯一的,就为表添加一个主键。

2. 如果要写代码来确保表中的一个单独的列是唯一的,就为表添加一个约束。

3. 如果要写代码确定表中的列的取值只能属于某个范围,就添加一个 Check 约束。

4. 如果要写代码来连接 父-子 表,就创建一个关系。

5. 如果要写代码来维护“一旦父表中的一行发生变化,连带变更子表中的相关行”,就启 用级联删除和更新。

6. 如果要调用大量的 Join 来进行一个查询,就创建一个视图。

7. 如果要逐条的写数据库操作的语句来完成一个业务规则,就使用存储过程。

所有表示时间的字段,统一以 Date 来作为结尾。

所有表示数目的字段,都应该以 Count 作为结尾。

最好使用单数的形式给表命名:

Customer而非Customers

避免无谓的表格后缀:

Guest而非GuestInfo

多对多关系中连接表的命名:

建议的写法是将两个表的表名 合并(如果表名比较长可做简化),此处如 StudentCourse

相关推荐