- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MySQL数据库开发规范13
平安金融科技 数据库(MySQL)开发规范
作者: Last Updated: 25/02/14 19:30:18
历史修订记录:
版本 修订人 修订时间 修订内容 1.0 李海军 2013-03-11 增加部分说明及修改 1.2 李海军 2013-07-29 增加连接池使用说明和memory引擎的控制 1.3 李海军 2014-02-25 增加了char类型,修改了timestamp的使用场合。
说明
本规范包含 平安金融科技 使用 MySQL 数据库时所需要遵循的所有对象设计(数据库,表,字段)所需要遵循的命名,对象设计,SQL 编写等的规范约定。
所有内容都为必须严格执行的项目,执行过程中有任何疑问,请联系 DBA Team 取得帮助。
概述
禁止明文传播数据库帐号和密码。
禁止开发工程师通过应用帐号登录生产数据库。
禁止应用在服务器安装MySQL客户端(可以安装开发包)。
禁止开发人员在SQL中添加 Hint,Hint只能由DBA审核后添加。
禁止使用悲观锁定,即读锁 select … for update。
禁止在开发代码中使用DDL语句,比如 truncate,alter table … 等。
禁止DML语句的where条件中包含恒真条件(如:1=1)。
1. 命名规范
总则
数据库对象名仅可包含小写英文字母、数字、下划线(_)三类字符,并以英文字母开头。
数据库对象命名禁止使用MySQL保留字。
多个单词之间用下划线(_)分隔。
对象名称长度若超过限制,则使用简写/缩写命名。
1.1. 数据库命名
数据库以"db_"前缀 + "站点名_"前缀及其所服务的应用名称命名。
1.2. 表命名
所属同一模块的表必须以模块名作为前缀命名。
历史数据表在原表基础上增加"_his"后缀命名。
1.3. 字段命名
布尔意义的字段以"_flag"作为后缀,前接动词。如:表示逻辑删除意义的字段可命名为 delete_flag。
各表间相同意义的字段(如:作为连接关系的引用字段)使用相同的字段名。
1.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;
索引需求:c1唯一,c2和c3 组合索引:uk_order_item_c1, idx_order_item_c2_c3
字段实际意义:是否已删除;
标准字段名:delete_flag;
字段 order.order_id被order_item引用;
order_item 表中与之对应的字段命名必须为:order_id
2. 对象设计规范
总则
所有表、字段必须添加能够清楚表示其含义的注释。状态类字段的注释中必须明确列出各状态值的说明。
MySQL数据库中仅可以使用下文提及的数据类型。
2.1. 数据类型
2.1.1. 数值类型
DECIMAL(M,D)
当表示定点小数的情况下使用该类型。定点数在MySQL内部以字符串形式存储,比浮点数更精确,适合用来表示货币等精度高的数据。
INT系列
所有整数类型字段使用INT(TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT),根据所存放的数据大小选择合适的子类型,且所有INT类型都不使用长度限制。
2.1.2. 字符串类型
VARCHAR
所有可变长度的字段均使用VARCHAR类型,对于有限类别的字段(如性别、状态等),均建议使用VARCHAR类型存储能明显表现其意义的字符串。
TEXT系列
仅当需存储的字节数可能超过20000时,使用TEXT系列类型(TEXT、MEDIUMTEXT、LONGTEXT)。并和原表进行分拆,与原表主键组成新表存储,且每个表只允许有一个TEXT系列类型字段。
仅当时,使用类型。
2.1.3. 时间类型
DATE
只需要精确到天的字段使用DATE类型。精确到"天"的取当前时期的操作使用CURDATE()函数实现。 -DATETIME
需要精确到时间(时、分、秒)的字段使用DATETIME类型。精确到"秒"的取当前时间的操作使用NOW()函数实现。raw_update_time字段使用,其它字段不允许使用该类型。取值范围:'1970-01-01 00:00:0
您可能关注的文档
- MOOC先秦君子风范课后参考答案..docx
- mooc关爱生命-急救与自救习题..docx
- MoldFlow基础培训..doc
- moocanalogelectronic题库..docx
- MOOC自然灾害与人..docx
- MOOC毛概课后题答案..docx
- Moravec算子提取特征点..doc
- morphy原汁机---171种蔬果汁自制方法..doc
- MOSDC模型..docx
- MOS的物理机制..doc
- 山东省临沂市沂水县2023-2024学年高一下学期期中考试历史试题.docx
- 江苏省泰州市靖江高级中学2023-2024学年高二下学期4月期中考试物理试题(无答案).docx
- 新疆部分名校2023-2024学年高二下学期期中联合考试语文试题.docx
- 湖南省岳阳市岳阳县第一中学2023-2024学年高三下学期4月期中考试数学试题.docx
- 山东省烟台市2023-2024学年高二下学期4月期中生物试题(无答案).docx
- 江苏省靖江高级中学2023-2024学年高二下学期期中地理试题(无答案).docx
- 四川省甘孜藏族自治州某重点中学2023-2024学年高一下学期4月期中考试物理试题.docx
- 湖北省武汉市华中师范大学第一附属中学2023-2024学年高二下学期4月期中英语试题(无答案).docx
- 四川省成都市金牛区成都市实验外国语学校2024年高三三模考试生物试题.docx
- 浙江省宁波市北仑中学2023-2024学年高二下学期期中考试物理试题.docx
文档评论(0)