一、数据库命名规范
1、字符限制:数据库名称只能包含26个英文字母(区分大小写)、0-9这十个自然数和下划线'_',共63个字符,不能出现其他字符。
2、长度限制:所有数据库对象命名不得超过30个字符,变量名的长度限制为29个字符(不包括标识字符@)。
3、避免保留字:数据库名称不能与MySQL的保留字冲突,例如SELECT、INSERT、UPDATE等,以避免语法错误或查询异常。
4、简洁明了:数据库名称应简洁明了,尽量使用有意义的英文单词或缩写,方便后续管理和维护,可以使用“ecommerce_db”表示电子商务数据库。
5、统一格式:正式数据库名使用小写英文以及下划线组成,尽量说明是那个应用或者系统在使用的。“web_19floor_net”。
6、备份数据库命名:备份数据库名使用正式库名加上备份时间组成,如“web_19floor_net_20070403”。
二、表命名规范
1、前缀使用:数据表名使用小写英文以及下划线组成,尽量说明是那个应用或者系统在使用的,相关应用的数据表使用同一前缀,例如论坛的表使用“cdb_”前缀,博客的数据表使用“supe_”前缀。
2、单数形式:表名称应使用单数形式,表示一个实体。
3、含义明确:表名应该能够清晰地表达表的结构和含义,user_info”表示用户信息表,“order_info”表示订单信息表。
4、避免保留字和关键字冲突:表名不能与MySQL的保留字冲突,例如不能使用“group”作为表名,因为它与MySQL的GROUP BY关键字冲突。
5、备份表命名:备份数据表名使用正式表名加上备份时间组成,如“web_user_20070403”。
三、字段命名规范
1、单词组合:字段名称使用单词组合完成,首字母小写,后面单词的首字母大写,最好是带表名前缀。“web_user”表的字段可以是“userId”、“userName”、“userPassword”。
2、一致性:保持字段名和类型的一致性,假如数据类型在一个表里是整数,在另一个表里也应保持一致,避免变成字符型。
3、相关联字段统一名称:表与表之间的相关联字段要用统一名称,web_user”表里的“userId”和“web_group”表里面的“userId”相对应。
四、索引命名规范
1、唯一索引:使用“uni + 字段名”来命名,uni_uid”。
2、非唯一索引:使用“idx + 字段名”来命名,idx_uname_mobile”。
3、组合索引:理解组合索引最左前缀原则,避免重复建设索引。
五、视图命名规范
1、前缀使用:视图名以“v”开头,表示view,完整结构是“v+视图内容含义缩写”,如果视图只来源单个表,则为“v+表名”;如果视图由几个表关联产生就用“v+下划线(_)连接几个表名”。
六、存储过程命名规范
1、前缀使用:存储过程名以“sp”开头,表示存储过程(storage procedure),之后多个单词以下划线(_)进行连接,存储过程中的输入参数以“i_”开头,输出参数以“o_”开头。
七、函数命名规范
1、前缀使用:函数名以“func”开始,表示function,之后多个单词以下划线(_)进行连接,函数命名中应体现其功能。
八、触发器命名规范
1、前缀使用:触发器以“trig”开头,表示trigger触发器,基本部分描述触发器所加的表,触发器名尽量不超过30个字符,后缀(_i,_u,_d)表示触发条件的触发方式(insert,update或delete)。
九、约束命名规范
1、唯一约束:uk_表名称_字段名,uk是UNIQUE KEY的缩写。
2、外键约束:fk_表名,后面紧跟该外键所在的表名和对应的主表名(不含t_),ALTER TABLE t_user ADD CONSTRAINT fk_user_dept FOREIGN KEY(depno) REFERENCES t_dept (id)。
3、非空约束:建议所有字段默认非空(not null),不同数据类型必须给出默认值(default)。
MySQL数据库命名规范是确保数据库结构清晰、易于维护和扩展的关键因素之一,通过遵循这些规范,可以提高代码的可读性、可维护性和团队协作效率。