MySQL 数据库的设计规范
网址 :http://blog.csdn.net/yjjm1990/article/details/7525811 1.文档的建立日期、所属的单位。
2.数据库的命名规范、视图、
3.命名的规范:
1)避免只使用面向计算机的术语,尽量使用与业务相关的术语。
2)如果一个词可以在字典找到缩写的形式,尽量使用缩写形式。 eg:Dec(December)
3)可以删除单词的元音(词首字母除外)和每个单词的重复字母来缩写一个单词。eg:Current = Crnt,Address = Adr
4)不使用歧义的缩写。
5)尽量使用单数的表名。
6)避免使用无谓的表格后缀。
7)多对多关系的表使用多个相关表的单词合写。
eg:学生和课程的关系,多对多,学生和课程各自一张表,学生和课程的关系表表名为:StudentCourse,其中
StudentID、CourseID复合主键,以及Student和Course表的外键。
8)对一些具有共同特性的字段使用约定俗成的前/后缀。
eg:
1)发帖时间 PostTime => PostDate
2)登录次数的统计 LoginTime => LoginCount
3)含有链接的字段以Url结尾:ImagePath => ImageUrl
4)布尔类型以Is、Can、Has开头
5)外键的命名:表名+ID
4.数据库设计的建议:
在代码中要做下列的事情时:
1)确保表中的行是唯一的,为表加一个主键。
2)确保表中的单独的列是唯一的,为表添加一个约束。
3)确保表中列的取值只能属于某个范围,添加一个Check约束。
4)连接父-子表,就创建一个关系。
5)父表发生变化,连带变更子表的相关行,启用级联删除和更新。
6)大量的Join来进行查询,创建一个视图。
7) 需要逐条的写数据库语句来完成一个业务规则,就使用存储过程。
注意:触发器的使用需要实践体验。 5.字段的类型不要随意设计成null,记住null和任意数的运算结果都是null。
6.Not Null可以接受空字符串,为了确保字段不空,可以加个Check约束。
7.确保字段的为唯一性,可以加个Unique的约束。
8.存储过程命名时,建议名词放前面,动词后面,这样当用企业管理器查看的时候,很整齐:
eg:
prEmployeeDelById
prEmployeeGetById
prEmployeeInsert
prEmployeeUpdate
prProductDelById
prProductGetById
10.存储过程的参数命名和对应的字段名相同。 其他的内容:
1.基本数据库对象的命名:
数据库对象 前缀 举例 备注
表(Table) 无 Student
字段(Column) 无 Title
视图(View) v vActivity
存储过程(Stored procedure) pr prDelOrder (系统的存储过程:_sp),pr用户自定义的存储过程
触发器(Tigger) tr trOrder_D (后缀:_I,_U,_D ,insert,update,delet操作)
索引(Index) ix_ ix_CustomerID
主键(primary key) pk_ pk_Admin
外键(Foreign key) fk_ fk_Order_OrderType ( fk_外键所在的表名_外键引用的表名)
Check约束(Check Constraint) ck_ ck_TableColumn
Unique约束 uq_ uq_TableColumn
用户定义的数据类型
(User-defined data type) udt udtPhone
用户定义函数
(User-defined function) fn fnDueDate eg:
Create Table Article
(
Id Int Identity(1,1) Not Null,
Title Varchar(50) Not Null Constraint uq_ArticleTitle Unique,
Keywords Varchar(50) Not Null,
Abstract Varchar(500) Not Null,
Author Varchar(50) Not Null Default '张子阳',
Type TinyInt Not Null Default 0 Constraint ck_ArticleType Check(Type in (0,1,2)), -- 0,原创;1,编译;2,翻译
IsOnIndex Bit Not Null Default 1, -- 是否显示在首页
Content Text Not Null,
SourceCode Varchar(100) Null, -- 程序源码的下载路径
Source Varchar(50) Not Null Default 'TraceFact', -- 文章出处
SrcUrl Varchar(150) Null, -- 文章出处的URL
PostDate DateTime Not Null Default GetDate(),
ViewCount Int Not Null Default 0,
ClassId Int Not Null -- 外键包含的字段,文章类别 Constraint pk_Article Primary Key(Id) -- 建立主键
)
MySQL 数据库的设计规范的更多相关文章
- MySQL数据库规范 (设计规范+设计规范+操作规范)
I 文档定义 1.1 编写目的 为了在软件生命周期内规范数据库相关的需求分析.设计.开发.测试.运维工作,便于不同团队之间的沟通协调,以及在相关规范上达成共识,提升相关环节的工作效率和系统的可维护性. ...
- MySql数据库表设计规范
建表规约 索引规约 SQL 语句 其他实战建议 选用utf8编码 建议使用InnoDB存储引擎 建议每张表都设置一个主键 建议字段定义为NOT NULL 唯一值字段要指定唯一性约束 ALTER TAB ...
- MYSQL数据库命名与其设计规范
你是否对获得MYSQL数据库命名与其设计规范 的实际操作感到十分头疼?如果是这样子的话,以下的文章将会给你相应的解决方案,以下的文章主要是介绍获得MYSQL数据库命名与其设计规范 的方案,以下就是相关 ...
- MYSQL数据库设计规范与原则
MYSQL数据库设计规范 1.数据库命名规范 采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线'_'组成; 命名简洁明确(长度不能超过30个字符); 例如:user, stat ...
- MySQL数据库设计规范
1. 规范背景与目的 MySQL数据库与 Oracle. SQL Server 等数据库相比,有其内核上的优势与劣势.我们在使用MySQL数据库的时候需要遵循一定规范,扬长避短.本规范旨在帮助或指导R ...
- 【转】MYSQL数据库设计规范与原则
转载出:http://www.cnblogs.com/lovekingly/p/5044278.htmlMYSQL数据库设计规范 1.数据库命名规范 采用26个英文字母(区分大小写)和0-9的自然数( ...
- mysql 数据库设计规范
MySQL数据库设计规范 目录 1. 规范背景与目的 2. 设计规范 2.1 数据库设计 2.1.1 库名 2.1.2 表结构 2.1.3 列数据类型优化 2.1.4 索引设计 2.1.5 分库分表. ...
- MYSQL数据库设计规范11111
MYSQL数据库设计规范 1.数据库命名规范 采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线'_'组成; 命名简洁明确(长度不能超 ...
- MySQL数据库命名及设计规范
1.设计原则 1) 标准化和规范化 数据的标准化有助于消除数据库中的数据冗余.标准化有好几种形式,但 Third Normal Form(3NF)通常被认为在性能.扩展性和数据完整性方面达到了最好平衡 ...
随机推荐
- 面试贴:java异常小结
java的异常处理在面试中通常是个敏感的话题,这里我从整体框架方面稍微作一下我的小结. java的异常都继承Throwable这个类,也就是都可以抛出来的异常,在这个祖先类下,又分为如下子类: 1.E ...
- C#中Path类的常用方法
场景 打开VS,输入Path,我们可以看到其定义. 都是静态方法,所以我们可以使用类名直接调用. 实现 新建命令行程序,编码如下: string str = @"C:\Users\Admin ...
- Python机器学习笔记:卷积神经网络最终笔记
这已经是我的第四篇博客学习卷积神经网络了.之前的文章分别是: 1,Keras深度学习之卷积神经网络(CNN),这是开始学习Keras,了解到CNN,其实不懂的还是有点多,当然第一次笔记主要是给自己心中 ...
- 学生管理系统——ArrayList集合
此学生管理系统利用了集合ArrayList实现了对学生的增删改查:利用数组中的方法实现分数排序:运用String类的equals实现登录功能的字符串比较. 管理员类: package data; pu ...
- Linux 笔记 - 几个常用且重要的命令
博客地址:http://www.moonxy.com Linux 系统中提供了大量的命令,从文件目录管理,用户管理,到系统监控等等,功能非常丰富,但有几个是常用且重要的命令. 1. 命令 grep 作 ...
- 无法解析的外部符号,该符号在xxx函数中被引用
无法解析的外部符号.........,该符号在函数.........被引用 在我们敲代码的过程中,我们偶尔会遇到这个问题,这个问题大多数都是因为你自己的程序有问题,而不是缺少相应的库文件.话不多说,直 ...
- Android开发中常用Dialog(普通弹窗&时间选择器&日历选择器)
引言 开发中,我们会有很多地方使用 Dialog 来展示一些提示信息或设置信息.如:用户提示.进度展示.时间设置.日期设置等. 下面我和大家一些学习下Android中常用的几种Dialog吧~ * 首 ...
- [C++]面向对象的程序设计——重要概念
1.面向对象程序设计的核心思想是数据抽象.继承和动态绑定.通过使用数据抽象可以将类的接口与实现分离:使用继承,可以定义相似的类型并对其相似的关系建模:使用动态绑定,可以在一定程度上忽略相似类型的区 ...
- Spring Boot + WebSocket 学习笔记
首先需要了解一下背景,什么是WebSocket以及为什么要用WebSocket. 在常见的Web应用中,客户端与服务器通信,都是通过HTTP协议进行通信,客户端一次请求,服务端一次响应.而WebSoc ...
- Qt 做一个类似微信滑动聊天界面的demo
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://www.cnblogs.com/lihuidashen/p/115889 ...