MySQL数据库名称规范是确保数据库结构清晰、易于维护和扩展的重要环节,以下是MySQL数据库命名规范的详细介绍:
数据库命名规范
1、命名唯一性:在MySQL中,每个数据库的名称必须是唯一的,不能有两个数据库使用同一个名称,数据库名称也是区分大小写的,因此需要确保数据库名称的大小写一致。
2、命名简洁性:数据库名称应该简洁明了,尽量使用有意义的英文单词或缩写,方便后续管理和维护,避免使用过于复杂的单词或长字符串,以减少输入错误和阅读困难。
3、避免保留词:数据库名称不能与MySQL的保留字冲突,否则可能会导致语法错误或查询异常,在命名数据库时,需要避开像SELECT、INSERT、UPDATE等保留字。
表命名规范
1、命名唯一性:每个表在同一个数据库中的名称也必须是唯一的,不能有两个表使用同一个名称,表名称也是区分大小写的。
2、命名规范:表名应该采用小写字母和下划线的组合形式,尽量避免使用大写字母或特殊字符,使用”user_info”而不是”User_Info”或”USER_INFO”,尽量避免使用单个字母作为表名,以增加可读性和可维护性。
3、表名含义明确:表名应该能够清晰地表达表的结构和含义,方便后续的数据处理和维护,可以使用”user_info”来表示用户信息表,”order_info”来表示订单信息表,避免使用模糊或无意义的表名,以提高可读性和可维护性。
4、避免保留词和关键字冲突:表名不能与MySQL的保留字冲突,否则可能会导致语法错误或查询异常,在命名表时,需要避开像SELECT、INSERT、UPDATE等保留字,还需要注意与MySQL关键字冲突的问题,例如使用”group”作为表名可能会与MySQL的GROUP BY关键字冲突。
字段命名规范
1、字段命名规范:字段名称使用单词组合完成,首字母小写,后面单词的首字母大写,最好是带表名前缀,如 web_user 表的字段:userId、userName、userPassword,表与表之间的相关联字段要用统一名称,如 web_user 表里面的 userId 和 web_group 表里面的 userId 相对应。
2、字段类型规范:用尽量少的存储空间来存数一个字段的数据,比如能用int的就不用char或者varchar;能用tinyint的就不用int;能使用varchar(20)的就不用varchar(255),时间戳字段尽量用int型,如created:表示从 ‘19700101 08:00:00’开始的int秒数,采用英文单词的过去式;gmtCreated:表示datetime类型的时间,即形如 ‘19800101 00:00:00’的时间串,Java中对应的类型为Timestamp。
索引命名规范
1、唯一索引:使用uni + 字段名 来命名:create unique index uni_uid on t_user_basic(uid)。
2、非唯一索引:使用idx + 字段名 来命名:create index idx_uname_mobile on t_user_basic(uname,mobile)。
3、索引名长度:索引名尽量不超过50个字符,命名应该使用小写,组合索引的字段不宜太多,不然也不利于查询效率的提升,多单词组成的列名,取尽可能代表意义的缩写,如 test_contact表member_id和friend_id上的组合索引:idx_mid_fid,理解组合索引最左前缀原则,避免重复建设索引,如果建立了(a,b,c),则相当于建立了(a), (a,b), (a,b,c)。
视图命名规范
1、视图名以v开头:表示view,完整结构是v+视图内容含义缩写,如果视图只来源单个表,则为v+表名,如果视图由几个表关联产生就用v+下划线(_)连接几个表名,视图名尽量不超过30个字符,如超过30个字符则取简写,除非特别需要,严禁开发人员创建视图,命名应使用小写。
存储过程命名规范
1、存储过程名以sp开头:表示storage procedure,之后多个单词以下划线(_)进行连接,存储过程命名中应体现其功能,存储过程名尽量不能超过30个字符,存储过程中的输入参数以i_开头,输出参数以o_开头,命名应使用小写。
函数命名规范
1、函数名以func开始:表示function,之后多个单词以下划线(_)进行连接,函数命名中应体现其功能,函数名尽量不超过30个字符,命名应使用小写。
触发器命名规范
1、触发器以trig开头:表示trigger 触发器,基本部分描述触发器所加的表,触发器名尽量不超过30个字符,后缀(_i,_u,_d),表示触发条件的触发方式(insert,update或delete),命名应使用小写。
约束命名规范
1、唯一约束:uk_表名称_字段名,uk是UNIQUE KEY的缩写,比如给一个部门的部门名称加上唯一约束,来保证不重名,如下:ALTER TABLE t_dept ADD CONSTRAINT un_name UNIQUE(name)。
2、外键约束:fk_表名_字段名_主表名,子表名和父表名用下划线(_)分隔,如 ALTER TABLE t_user ADD CONSTRAINT fk_user_dept FOREIGN KEY(depno) REFERENCES t_dept (id)。
3、非空约束:如无特殊需要,建议所有字段默认非空(not null),不同数据类型必须给出默认值(default),逻辑型的默认值为数值0表示为“假”,数值1表示为“真”,datetime、smalldatetime类型的字段没有默认值,必须为NULL。
SQL语言编码规范
1、大小写规范:所有关键字必须大写,如:INSERT、UPDATE、DELETE、SELECT及其子句,IF……ELSE、CASE、DECLARE等,所有函数及其参数中除用户变量以外的部分必须大写,在定义变量时用到的数据类型必须小写。
2、注释:注释可以包含在批处理中,在触发器、存储过程中包含描述性注释将大大增加文本的可读性和可维护性,本规范建议注释以英文为主,注释尽可能详细、全面创建每一数据对象前,应具体描述该对象的功能和用途,传入参数的含义应该有所说明,如果取值范围确定,也应该一并说明,取值有特定含义的变量(如boolean类型变量),应给出每个值的含义,注释语法:单行注释、多行注释,单行注释:注释前有两个连字符()对变量、条件子句可以采用该类注释,多行注释:符号之间的内容为注释内容,对某项完整的操作建议使用该类注释,注释简洁,同时应描述清晰,函数注释:编写函数文本如触发器、存储过程以及其他数据对象时,必须为每个函数增加适当注释,该注释以多行注释为主,主要描述该函数的功能以及各参数的意义。
十一、FAQs
1、问题:为什么MySQL数据库名称不能与保留字冲突?
答案:因为如果数据库名称与保留字冲突,可能会导致语法错误或查询异常,影响数据库的正常操作。
2、问题:为什么表名要全部使用小写字母?
答案:因为MySQL在Windows系统下是不区分大小写的,但在其他系统下,如Linux,是区分大小写的,为了保持兼容性和一致性,建议表名全部使用小写字母。
3、问题:为什么要避免在数据库中使用中文命名?
答案:因为使用中文命名可能导致在不同环境或平台上出现编码问题,从而引发乱码或无法识别的情况,中文命名也不便于国际化和跨语言的交流。
4、问题:为什么字段名要尽量不超过三个英文单词?
答案:因为过长的字段名会增加输入错误的风险,也会降低代码的可读性,保持字段名简短且具有描述性有助于提高代码的可维护性。
5、问题:为什么建议为每个表填写描述信息?
答案:因为填写描述信息有助于团队成员更好地理解表的结构和用途,提高团队协作效率,在数据库版本升级或迁移时,描述信息也能提供重要的参考依据。
原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/1106079.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复