mysql数据库开发规范1.3

mysql数据库开发规范1.3

ID:22518973

大小:71.50 KB

页数:8页

时间:2018-10-29

mysql数据库开发规范1.3_第1页
mysql数据库开发规范1.3_第2页
mysql数据库开发规范1.3_第3页
mysql数据库开发规范1.3_第4页
mysql数据库开发规范1.3_第5页
资源描述:

《mysql数据库开发规范1.3》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、平安金融科技数据库(MySQL)开发规范作者:简朝阳LastUpdated:25/02/1419:30:18历史修订记录:版本修订人修订时间修订内容1.01.1李海军2013-03-11增加部分说明及修改1.2李海军2013-07-29增加连接池使用说明和memory引擎的控制1.3李海军2014-02-25增加了char类型,修改了timestamp的使用场合。说明ñ本规范包含平安金融科技使用MySQL数据库时所需要遵循的所有对象设计(数据库,表,字段),所需要遵循的命名,对象设计,SQL编写等的规范约定。ñ所有内容都为必须严格执行的项目

2、,执行过程中有任何疑问,请联系DBATeam取得帮助。概述ñ禁止明文传播数据库帐号和密码。ñ禁止开发工程师通过应用帐号登录生产数据库。ñ禁止应用在服务器安装MySQL客户端(可以安装开发包)。ñ禁止开发人员在SQL中添加Hint,Hint只能由DBA审核后添加。ñ禁止使用悲观锁定,即读锁select…forupdate。ñ禁止在开发代码中使用DDL语句,比如truncate,altertable…等。ñ禁止DML语句的where条件中包含恒真条件(如:1=1)。1.命名规范总则ñ数据库对象名仅可包含小写英文字母、数字、下划线(_)三类字符,

3、并以英文字母开头。ñ数据库对象命名禁止使用MySQL保留字。ñ多个单词之间用下划线(_)分隔。ñ对象名称长度若超过限制,则使用简写/缩写命名。1.1.数据库命名ñ数据库以"db_"前缀+"站点名_"前缀及其所服务的应用名称命名。1.2.表命名ñ所属同一模块的表必须以模块名作为前缀命名。ñ历史数据表在原表基础上增加"_his"后缀命名。1.3.字段命名ñ布尔意义的字段以"_flag"作为后缀,前接动词。如:表示逻辑删除意义的字段可命名为delete_flag。ñ各表间相同意义的字段(如:作为连接关系的引用字段)使用相同的字段名。1.4.索引命

4、名ñ唯一索引以uk_tablename_columnnames方式命名ñ普通索引以idx_tablename_columnnames方式命名ñ组合索引以idx_tablename_column1_column2...方式命名示例ñ站点名:maymayñ模块名:order;ñ数据表:item;ñ字段组成:order_item_id,add_time,raw_update_time,c1,c2,c3,c4,c5ñ标准数据库名:db_maymay_order;ñ标准数据表名:order_item;ñ历史数据表名:order_item_his;ñ索

5、引需求:c1唯一,c2和c3组合索引:uk_order_item_c1,idx_order_item_c2_c3ñ字段实际意义:是否已删除;ñ标准字段名:delete_flag;ñ字段order.order_id被order_item引用;ñorder_item表中与之对应的字段命名必须为:order_id2.对象设计规范总则ñ所有表、字段必须添加能够清楚表示其含义的注释。状态类字段的注释中必须明确列出各状态值的说明。ñMySQL数据库中仅可以使用下文提及的数据类型。2.1.数据类型2.1.1.数值类型ñDECIMAL(M,D)当表示定点小

6、数的情况下使用该类型,禁止使用浮点类型,会带来不精确。定点数在MySQL内部以字符串形式存储,比浮点数更精确,适合用来表示货币等精度高的数据。ñINT系列所有整数类型字段使用INT(TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT),根据所存放的数据大小选择合适的子类型,且所有INT类型都不使用长度限制。2.1.2.字符串类型ñVARCHAR所有可变长度的字段均使用VARCHAR类型,对于有限类别的字段(如性别、状态等),均建议使用VARCHAR类型存储能明显表现其意义的字符串。ñTEXT系列仅当需存储的字节数可能

7、超过20000时,使用TEXT系列类型(TEXT、MEDIUMTEXT、LONGTEXT)。并和原表进行分拆,与原表主键组成新表存储,且每个表只允许有一个TEXT系列类型字段。ñCHAR仅当字段确定为定长,且将来不会修改长度时,使用CHAR类型。上线以后不允许修改字段类型。谨慎使用2.1.3.时间类型ñDATE只需要精确到天的字段使用DATE类型。精确到"天"的取当前时期的操作使用CURDATE()函数实现。-DATETIME需要精确到时间(时、分、秒)的字段使用DATETIME类型。精确到"秒"的取当前时间的操作使用NOW()函数实现。取

8、值范围:'1000-01-01'到'9999-12-31'TIMESTAMP该类型仅允许raw_update_time字段使用,其它字段不允许使用该类型。取值范围:'1970-0

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。