数据库设计规范

时间:2024.3.31

文档信息

文档修订历史


数据库约定

对应于XXXX MYSQL数据库环境的数据库类型定义如下表:

数据库字符集选择UTF8字符集 (建库时确定)

1.    数据库元素命名规范

长度约定:字段名,表名,视图名称等长度不能超过25个字符

1.1.  表命名规范


1.2.  字段命名规范

l  字段名

字段名称必须用字母开头,采用有特征含义的单词或缩写,不能用双引号包含。以下划线作为单词间的分隔,例如 PLANT_NUM

l  表的主键必须是“表名_ID”,类型必须是INT(11)

字段保留名称

1.2.1.  字符型

固定长度的字串类型采用char,长度不固定的字串类型采用varchar。避免在长度不固定的情况下采用char类型。如果在数据迁移等出现以上情况,则必须使用trim()函数截去字串后的空格。

1.2.2.  数字型

数字型字段尽量采用int类型。

1.2.3.  日期和时间

n  系统时间

由数据库产生的系统时间首选数据库的日期型,如DATE类型。

n  外部时间

由数据导入或外部应用程序产生的日期时间类型采用varchar类型,数据格式采用:YYYYMMDDHH24MISS。

1.2.4.   大字段

如无特别需要,避免使用大字段(blob,clob,long,image等)。

1.2.5.  布尔类型

统一采用TINYINT(1)表示,0代表false, 1代表 true

1.2.6.  国际化信息表示

应用需要支持多国语言文字。所有数据库表中需要显示用的字段,都需要以 “_ZH”, “_EN”,”_DE”结尾作为字段名,以区分不同Locale的字段信息。

1.3.  索引

l  普通索引

前缀为IDX_。索引名称应是 前缀+表名+构成的字段名。如果复合索引的构成字段较多,则只包含第一个字段,并添加序号。表名可以去掉前缀。

l  主键索引

前缀为IDX_PK_。索引名称应是 前缀+表名+构成的主键字段名,在创建表时候用using index指定主键索引属性。

l  唯一索引

前缀为IDX_UK_。索引名称应是 前缀+表名+构成的字段名。

l  外键索引

前缀为IDX_FK_。索引名称应是 前缀+表名+构成的外键字段名。

l  函数索引

前缀为IDX_func_。索引名称应是 前缀+表名+构成的特征表达字符。

l  蔟索引

前缀为IDX_clu_。索引名称应是 前缀+表名+构成的簇字段。

1.4.  视图

普通视图,前缀为V_。按业务操作命名视图。

物化视图,前缀为MV_。按业务操作命名实体化视图。

1.5.  存储过程

前缀为PROC_ 。按业务操作命名存储过程

1.6.  触发器

前缀为TRIG_ 。触发器名应是 前缀 + 表名 + 触发器名。

1.7.  函数

前缀为FUNC_ 。按业务操作命名函数

1.8.  数据包

前缀为PKG_ 。按业务操作集合命名数据包。

1.9.  序列

前缀为SEQ_ 。按业务属性命名。

1.10.  表空间

l  公用表空间

前缀为TBS_ 。 根据应用名字命名,例如: TBS_<缩写的应用名> 。

l  专用表空间

TBS_<缩写的应用名>_xxx。xxx可以是Index, BLOB/CLOB属性, Aux其它辅助信息。

1.11.  数据文件

<表空间名>nn.dbf 。nn =1,2,3,4,…等。

1.12.  普通变量

前缀为VAR_ 。 存放字符、数字、日期型变量。

1.13.  游标变量

前缀为CUR_ 。存放游标记录集。

1.14.  记录型变量

前缀为REC_。 存放记录型数据。

1.15.  表类型变量

前缀为TAB_。 存放表类型数据。

1.16.  数据库链

前缀为DBL_ 。 表示分布式数据库外部链接关系。

2.    建模设计

XXXX项目推荐采用PowerDesign V12版本进行数据库模型设计。

2.1.  范式

如无性能上的必须原因,应该使用关系数据库理论,达到较高的范式,避免数据冗余,但是如果在数据量上与性能上无特别要求,考虑到实现的方便性可以有适当的数据冗余,但基本上要达到3NF。

如非确实必要,避免一个字段中存储多个标志的做法。如11101表示5个标志的一种取值。这往往是增加复杂度,降低性能的地方。

2.2.  特殊表设计原则

l  分区表

对于数据量比较大的表,根据表数据的属性进行分区,以得到较好的性能。如果表按某些字段进行增长,则采用按字段值范围进行范围分区;如果表按某个字段的几个关键值进行分布,则采用列表分区;对于静态表,则采用hash分区或列表分区;在范围分区中,如果数据按某关键字段均衡分布,则采用子分区的复合分区方法。

l  聚蔟表

如果某几个静态表关系比较密切,则可以采用聚蔟表的方法。

2.3.  完整性设计原则

l  主键约束

关联表的父表要求有主健,主健字段或组合字段必须满足非空属性和唯一性要求。对于数据量比较大的父表,要求指定索引段。

l  外键关联

对于关联两个表的字段,一般应该分别建立主键、外键。实际是否建立外键,根据对数据完整性的要求决定。为了提高性能,对于数据量比较大的标要求对外健建立索引。对于有要求级联删除属性的外键,必须指定on delete cascade 。

l  NULL值

对于字段能否null,应该在sql建表脚本中明确指明,不应使用缺省。由于NULL值在参加任何运算中,结果均为NULL。所以在应用程序中必须利用nvl()函数把可能为NULL值得字段或变量转换为非NULL的默认值。例如:NVL(sale,0)。

l  Check条件

对于字段有检查性约束,要求指定check规则。

l  触发器

触发器是一种特殊的存储过程,通过数据表的DML操作而触发执行,起作用是为确保数据的完整性和一致性不被破坏而创建,实现数据的完整约束。触发器的before或after事务属性的选择时候,对表操作的事务属性必须与应用程序事务属性保持一致,以避免死锁发生。在大型导入表中,尽量避免使用触发器。

l  注释

表、字段等应该有中文名称注释,以及需要说明的内容。

2.4.  索引设计

对于查询中需要作为查询条件的字段,可以考虑建立索引。最终根据性能的需要决定是否建立索引。最常用的SQL查询应用大量数据来分析执行计划。

对于复合索引,索引字段顺序比较关键,把查询频率比较高的字段排在索引组合的最前面。

在分区表中,尽量采用local分区索引以方便分区维护。

应该为索引创建单独的表空间。除非是分区local索引,否则在创建索引时候必须指定指定索引段的tablespace、storage属性。

2.5.  视图设计

视图是虚拟的数据库表,在使用时要遵循以下原则:

l  从一个或多个库表中查询部分数据项;

l  为简化查询,将复杂的检索或字查询通过视图实现;

l  提高数据的安全性,只将需要查看的数据信息显示给权限有限的人员;

l  视图中如果嵌套使用视图,级数不得超过3级;

l  由于视图中只能固定条件或没有条件,所以对于数据量较大或随时间的推移逐渐增多的库表,不宜使用视图;可以采用实体化视图代替。

l  除特殊需要,避免类似Select * from [TableName] 而没有检索条件的视图;

l  视图中尽量避免出现数据排序的SQL语句。


第二篇:数据库设计规范与命名规则


数据库设计规范、技巧与命名规范

一、数据库设计过程

数据库技术是信息资源管理最有效的手段。

数据库设计是指:对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,有效存储数据,

满足用户信息要求和处理要求。

数据库设计的各阶段:

A、需求分析阶段:综合各个用户的应用需求(现实世界的需求)。

B、在概念设计阶段:形成独立于机器和各DBMS产品的概念模式(信息世界模型),用E-R图来描述。

C、在逻辑设计阶段:将E-R图转换成具体的数据库产品支持的数据模型,如关系模型,形成数据库逻辑模式。

然后根据用户处理的要求,安全性的考虑,在基本表的基础上再建立必要的视图(VIEW)形成数据的外模式。

D、在物理设计阶段:根据DBMS特点和处理的需要,进行物理存储安排,设计索引,形成数据库内模式。

1. 需求分析阶段

需求收集和分析,结果得到数据字典描述的数据需求(和数据流图描述的处理需求)。

需求分析的重点:调查、收集与分析用户在数据管理中的信息要求、处理要求、安全性与完整性要求。 需求分析的方法:调查组织机构情况、各部门的业务活动情况、协助用户明确对新系统的各种要求、确定新系统的边界。

常用的调查方法有: 跟班作业、开调查会、请专人介绍、询问、设计调查表请用户填写、查阅记录。 分析和表达用户需求的方法主要包括自顶向下和自底向上两类方法。自顶向下的结构化分析方法(Structured Analysis,

简称SA方法)从最上层的系统组织机构入手,采用逐层分解的方式分析系统,并把每一层用数据流图和数据字典描述。

数据流图表达了数据和处理过程的关系。系统中的数据则借助数据字典(Data Dictionary,简称DD)来描述。

2. 概念结构设计阶段

通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型,可以用E-R图表示。 概念模型用于信息世界的建模。概念模型不依赖于某一个DBMS支持的数据模型。概念模型可以转换为计算机上某一

DBMS 支持的特定数据模型。

概念模型特点:

(1) 具有较强的语义表达能力,能够方便、直接地表达应用中的各种语义知识。

(2) 应该简单、清晰、易于用户理解,是用户与数据库设计人员之间进行交流的语言。

概念模型设计的一种常用方法为IDEF1X方法,它就是把实体-联系方法应用到语义数据模型中的一种语义模型化技术,

用于建立系统信息模型。

使用IDEF1X方法创建E-R模型的步骤如下所示:

2.1 初始化工程

这个阶段的任务是从目的描述和范围描述开始,确定建模目标,开发建模计划,组织建模队伍,收集源材料,制定约束和

规范。收集源材料是这阶段的重点。通过调查和观察结果,业务流程,原有系统的输入输出,各种报表,收集原始数据,

形成 了基本数据资料表。

2.2 定义实体

实体集成员都有一个共同的特征和属性集,可以从收集的源材料——基本数据资料表中直接或间接标识出大部分实体。

根据源材料名字表中表示物的术语以及具有“代码”结尾的术语,如客户代码、代理商代码、产品代码等将其名词部分代表的

实体标识出来,从而初步找出潜在的实体,形成初步实体表。

2.3 定义联系

IDEF1X模型中只允许二元联系,n元联系必须定义为n个二元联系。根据实际的业务需求和规则,使用实体联系矩阵来标识实体间的二元关系,然后根据实际情况确定出连接关系的势、关系名和说明,确定关系类型,是标识关系、非标识关系(强制的或可选的)还是非确定关系、分类关系。如果子实体的每个实例都需要通过和父实体的关系来标识,则为标识关系,否则为非标识关系。非标识关系中,如果每个子实体的实例都与而且只与一个父实体关联,则为强制的,否则为非强制的。如果父实体与子实体代表的是同一现实对象,那么它们为分类关系。

2.4 定义码

通过引入交叉实体除去上一阶段产生的非确定关系,然后从非交叉实体和独立实体开始标识侯选码属性,以便唯一识别每个实体的实例,再从侯选码中确定主码。为了确定主码和关系的有效性,通过非空规则和非多值规则来保证,即一个实体实例的一个属性不能是空值,也不能在同一个时刻有一个以上的值。找出误认的确定关系,将实体进一步分解,最后构造出IDEF1X模型的键基视图(KB图)。

2.5 定义属性

从源数据表中抽取说明性的名词开发出属性表,确定属性的所有者。定义非主码属性,检查属性的非空及非多值规则。此外,还要检查完全依赖函数规则和非传递依赖规则,保证一个非主码属性必须依赖于主码、整个主码、仅仅是主码。以此得到了至少符合关系理论第三范式的改进的IDEF1X模型的全属性视图。

2.6 定义其他对象和规则

定义属性的数据类型、长度、精度、非空、缺省值、约束规则等。定义触发器、存储过程、视图、角色、同义词、序列等对象信息。

3. 逻辑结构设计阶段

将概念结构转换为某个DBMS所支持的数据模型(例如关系模型),并对其进行优化。设计逻辑结构应该选择最适于描述与表达相应概念结构的数据模型,然后选择最合适的DBMS。

将E-R图转换为关系模型实际上就是要将实体、实体的属性和实体之间的联系转化为关系模式,这种转换一般遵循如下原则:一个实体型转换为一个关系模式。实体的属性就是关系的属性。实体的码就是关系的码。 数据模型的优化,确定数据依赖,消除冗余的联系,确定各关系模式分别属于第几范式。确定是否要对它

们进行合并或分解。一般来说将关系分解为3NF的标准,即:

表内的每一个值都只能被表达一次。

表内的每一行都应该被唯一的标识(有唯一键)。

表内不应该存储依赖于其他键的非键信息。

4. 数据库物理设计阶段

为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法)。根据DBMS特点和处理的需要,进行物理存储安排,设计索引,形成数据库内模式。

5. 数据库实施阶段

运用DBMS提供的数据语言(例如SQL)及其宿主语言(例如C),根据逻辑设计和物理设计的结果建立数据库,编制与调试应用程序,组织数据入库,并进行试运行。 数据库实施主要包括以下工作:用DDL定义数据库结构、组织数据入库 、编制与调试应用程序、数据库试运行 ,(Data Definition Language(DDL数据定义语言)用作开新数据表、设定字段、删除数据表、删除字段,管理所有有关数据库结构的东西)

●Create (新增有关数据库结构的东西,属DDL)

●Drop (删除有关数据库结构的东西,属DDL)

●Alter (更改结构,属DDL)

6. 数据库运行和维护阶段

在数据库系统运行过程中必须不断地对其进行评价、调整与修改。内容包括:数据库的转储和恢复、数据库的安全性、完整性控制、数据库性能的监督、分析和改进、数据库的重组织和重构造。

7. 建模工具的使用

为加快数据库设计速度,目前有很多数据库辅助工具(CASE工具),如Rational公司的Rational Rose,CA公司的Erwin和Bpwin,Sybase公司的PowerDesigner以及Oracle公司的oracle Designer等。

ERwin主要用来建立数据库的概念模型和物理模型。它能用图形化的方式,描述出实体、联系及实体的属性。ERwin支持IDEF1X方法。通过使用ERwin建模工具自动生成、更改和分析IDEF1X模型,不仅能得到优秀的业务功能和数据需求模型,而且可以实现从IDEF1X模型到数据库物理设计的转变。ERwin工具绘制的模型对应于逻辑模型和物理模型两种。在逻辑模型中,IDEF1X工具箱可以方便地用图形化的方式构建和绘制实体联系及实体的属性。在物理模型中,ERwin可以定义对应的表、列,并可针对各种数据库管理系统自动转换为适当的类型。

设计人员可根据需要选用相应的数据库设计建模工具。例如需求分析完成之后,设计人员可以使用Erwin画ER图,将ER图转换为关系数据模型,生成数据库结构;画数据流图,生成应用程序。

二、数据库设计技巧

1. 设计数据库之前(需求分析阶段)

1.1 客户需求,包括用户未来需求变化。

1.2 了解企业业务类型,可以在开发阶段节约大量的时间。

1.3 重视输入(要记录的数据)、输出(报表、查询、视图)。

1.4 创建数据字典和ER 图表

数据字典(Data Dictionary,简称DD)是各类数据描述的集合,是关于数据库中数据的描述,即元数据,不

是数据本身。(至少应该包含每个字段的数据类型和在每个表内的主外键)。

数据项描述: 数据项名,数据项含义说明,别名,数据类型,长度,取值范围,取值含义,与其他数据项的逻辑关系

数据结构描述: 数据结构名,含义说明,组成:[数据项或数据结构]

数据流描述: 数据流名,说明,数据流来源,数据流去向, 组成:[数据结构],平均流量,高峰期流量

数据存储描述: 数据存储名,说明,编号,流入的数据流,流出的数据流,组成:[数据结构],数据量,存取方式

处理过程描述: 处理过程名,说明,输入:[数据流],输出:[数据流],处理:[简要说明]

ER 图表和数据字典可以让任何了解数据库的人都明确如何从数据库中获得数据。ER图对表明表之间关系很有用,而数据字典则说明了每个字段的用途以及任何可能存在的别名。对SQL 表达式的文档化来说这是完全必要的。

1.5定义标准的对象命名规范

数据库各种对象的命名必须规范。

2. 表和字段的设计(数据库逻辑设计)

表设计原则

1 准化和规范化

数据的标准化有助于消除数据库中的数据冗余。标准化有好几种形式,但Third Normal Form(3NF)通常被认为在性能、扩展性和数据完整性方面达到了最好平衡。简单来说,遵守3NF 标准的数据库的表设计原则是:“One Fact in One Place”即某个表只包括其本身基本的属性,当不是它们本身所具有的属性时需进行分解。表之间的关系通过外键相连接。它具有以下特点:有一组表专门存放通过键连接起来的关联数据。

2 数据驱动

采用数据驱动而非硬编码的方式,许多策略变更和维护都会方便得多,大大增强系统的灵活性和扩展性。

举例,假如用户界面要访问外部数据源(文件、XML 文档、其他数据库等),不妨把相应的连接和路径信息存储在用户界面支持的表里。如果用户界面执行工作流之类的任务(发送邮件、打印信笺、修改记录状态等),那么产生工作流的数据也可以存放在数据库里。角色权限管理也可以通过数据驱动来完成。事实上,如果过程是数据驱动的,你就可以把相当大的责任推给用户,由用户来维护自己的工作流过程。

3考虑各种变化

在设计数据库的时候考虑到哪些数据字段将来可能会发生变更。

4 表名、报表名和查询名的命名规范

(采用前缀命名)检查表名、报表名和查询名之间的命名规范。你可能会很快就被这些不同的数据库要素的名称搞糊涂了。你可以统一地命名这些数据库的不同组成部分,至少你应该在这些对象名字的开头用 Table、Query 或者 Report 等前缀加以区别。如果采用了 Microsoft Access,你可以用 qry、rpt、tbl 和 mod 等符号来标识对象(比如 tbl_Employees)。用 sp_company 标识存储过程,用 udf_ (或者类似的标记)标识自定义编写的函

数。

字段设计原则:

1 每个表中都应该添加的3 个有用的字段。

?dRecordCreationDate,在SQL Server 下默认为GETDATE()

?sRecordCreator,在SQL Server 下默认为NOT NULL DEFAULT USER

?nRecordVersion,记录的版本标记;有助于准确说明记录中出现null 数据或者丢失数据的原因

时效性数据应包括“最近更新日期/时间”字段。时间标记对查找数据问题的原因、按日期重新处理/重载数据和清除旧数据特别有用。

2 对地址和电话采用多个字段

描述街道地址就短短一行记录是不够的。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的灵活性。还有,电话号码和邮件地址最好拥有自己的数据表,其间具有自身的类型和标记类别。

3 表内的列[字段]的命名规则(采用前缀/后缀命名)、采用有意义的字段名

对列[字段]名应该采用标准的前缀和后缀。如键是数字类型:用 _N 后缀;字符类型:_C 后缀;日期类型:_D 后缀。再如,假如你的表里有好多“money”字段,你不妨给每个列[字段]增加一个 _M 后缀。

假设有两个表:

Customer 和 Order。Customer 表的前缀是 cu_,所以该表内的子段名如下:cu_name_id、cu_surname、cu_initials 和cu_address 等。Order 表的前缀是 or_,所以子段名是:

or_order_id、or_cust_name_id、or_quantity 和 or_description 等。

这样从数据库中选出全部数据的 SQL 语句可以写成如下所示:

Select * From Customer, Order Where cu_surname = "MYNAME" ;

and cu_name_id = or_cust_name_id and or_quantity = 1

在没有这些前缀的情况下则写成这个样子(用别名来区分):

Select * From Customer, Order Where Customer.surname = "MYNAME" ;

and Customer.name_id = Order.cust_name_id and Order.quantity = 1

第 1 个 SQL 语句没少键入多少字符。但如果查询涉及到 5 个表乃至更多的列[字段]你就知道这个技巧多有用了。

5 选择数字类型和文本类型的长度应尽量充足

假设客户ID 为10 位数长。那你应该把数据库表字段的长度设为12 或者13 个字符长。但这额外占据的空间却无需将来重构整个数据库就可以实现数据库规模的增长了。

6 增加删除标记字段

在表中包含一个“删除标记”字段,这样就可以把行标记为删除。在关系数据库里不要单独删除某一行;最好采用清除数据程序而且要仔细维护索引整体性。

7 提防大小写混用的对象名和特殊字符

采用全部大写而且包含下划符的名字具有更好的可读性(CUSTOMER_DATA),绝对不要在对象名的字符之间留空格。

8 小心保留词

要保证你的字段名没有和保留词、数据库系统或者常用访问方法冲突,比如,用 DESC 作为说明字段名。后果可想而知!DESC 是 DESCENDING 缩写后的保留词。表里的一个 SELECT * 语句倒是能用,但得到的却是一大堆毫无用处的信息。

9 保持字段名和类型的一致性

在命名字段并为其指定数据类型的时候一定要保证一致性。假如字段在表1中叫做“agreement_number”,就别在表2里把名字改成“ref1”。假如数据类型在表1里是整数,那在表2里可就别变成字符型了。当然在表1(ABC)有处键ID,则为了可读性,在表2做关联时可以命名为ABC_ID。

10避免使用触发器

触发器的功能通常可以用其他方式实现。在调试程序时触发器可能成为干扰。假如你确实需要采用触发器,你最好集中对它文档化。

3. 选择键和索引(数据库逻辑设计)

参考:《SQL优化-索引》一文

4. 数据完整性设计(数据库逻辑设计)

1完整性实现机制:

实体完整性:主键

参照完整性:

父表中删除数据:级联删除;受限删除;置空值

父表中插入数据:受限插入;递归插入

父表中更新数据:级联更新;受限更新;置空值

DBMS对参照完整性可以有两种方法实现:外键实现机制(约束规则)和触发器实现机制用户定义完整性:

NOT NULL;CHECK;触发器

2 用约束而非商务规则强制数据完整性

采用数据库系统实现数据的完整性。这不但包括通过标准化实现的完整性而且还包括数据的功能性。不要依赖于商务层保证数据完整性;它不能保证表之间(外键)的完整性所以不能强加于其他完整性规则之上。如果你在数据层确实采用了约束,你要保证有办法把更新不能通过约束检查的原因采用用户理解的语言通知用户界面。

3 强制指示完整性

在有害数据进入数据库之前将其剔除。激活数据库系统的指示完整性特性。这样可以保持数据的清洁而能迫使开发人员投入更多的时间处理错误条件。

4 使用查找控制数据完整性

控制数据完整性的最佳方式就是限制用户的选择。只要有可能都应该提供给用户一个清晰的价值列表供其选择。这样将减少键入代码的错误和误解同时提供数据的一致性。某些公共数据特别适合查找:国家代码、状态代码等。

5 采用视图

为了在数据库和应用程序代码之间提供另一层抽象,可以为应用程序建立专门的视图而不必非要应用程序直接访问数据表。这样做还等于在处理数据库变更时给你提供了更多的自由。

6 分布式数据系统

对分布式系统而言,在你决定是否在各个站点复制所有数据还是把数据保存在一个地方之前应该估计一下未来 5 年或者 10 年的数据量。当你把数据传送到其他站点的时候,最好在数据库字段中设置一些标记,在目的站点收到你的数据之后更新你的标记。为了进行这种数据传输,请写下你自己的批处理或者调度程序以特定时间间隔运行而不要让用户在每天的工作后传输数据。本地拷贝你的维护数据,比如计算常数和利息率等,设置版本号保证数据在每个站点都完全一致。

7 关系

如果两个实体之间存在多对一关系,而且还有可能转化为多对多关系,那么你最好一开始就设置成多对多关系。从现有的多对一关系转变为多对多关系比一开始就是多对多关系要难得多。

8 给数据保有和恢复制定计划

考虑数据保存策略并包含在设计过程中,预先设计你的数据恢复过程。采用可以发布给用户/开发人员的数据字典实现方便的数据识别同时保证对数据源文档化。编写在线更新来“更新查询”供以后万一数据丢失可以重新处理更新。

9 用存储过程让系统做重活

提供一整套常规的存储过程来访问各组以便加快速度和简化客户程序代码的开发。数据库不只是一个存放数据的地方,它也是简化编码之地。

5. 其他设计技巧

1 避免使用触发器

触发器的功能通常可以用其他方式实现。在调试程序时触发器可能成为干扰。假如你确实需要采用触发器,你最好集中对它文档化。

2 使用常用英语(或者其他任何语言)而不要使用编码

在创建下拉菜单、列表、报表时最好按照英语名排序。假如需要编码,可以在编码旁附上用户知道的英语。 3 保存常用信息

让一个表专门存放一般数据库信息非常有用。在这个表里存放数据库当前版本、最近检查/修复(对Access)、关联设计文档的名称、客户等信息。这样可以实现一种简单机制跟踪数据库,当客户抱怨他们的数据库没有达到希望的要求而与你联系时,这样做对非客户机/服务器环境特别有用。

4 包含版本机制

在数据库中引入版本控制机制来确定使用中的数据库的版本。时间一长,用户的需求总是会改变的。最终可能会要求修改数据库结构。把版本信息直接存放到数据库中更为方便。

5 编制文档

对所有的快捷方式、命名规范、限制和函数都要编制文档。

采用给表、列、触发器等加注释的 数据库工具。对开发、支持和跟踪修改非常有用。

对数据库文档化,或者在数据库自身的内部或者单独建立文档。这样,当过了一年多时间后再回过头来做第2 个版本,犯错的机会将大大减少。

6 测试、测试、反复测试

建立或者修订数据库之后,必须用用户新输入的数据测试数据字段。最重要的是,让用户进行测试并且同用户一道保证选择的数据类型满足商业要求。测试需要在把新数据库投入实际服务之前完成。

7 检查设计

在开发期间检查数据库设计的常用技术是通过其所支持的应用程序原型检查数据库。换句话说,针对每一

种最终表达数据的原型应用,保证你检查了数据模型并且查看如何取出数据。

三、数据库命名规范

1. 实体(表)的命名

1.1 基本原则

命名以表述实体的真实含义、方便辨认为目的,尽量不采用缩写,尽量使用大写或大写首字母英文单词, 不使用复数。同一字段名在数据库中应保持含义相同。不同含义的实体应该采用不同的字符表示,单词 间使用“-”分隔。禁止使用中文或拼音缩写进行命名,表名、字段名、视图名长度控制在5个单词之内, 总长度小于30个字符

1.2 如遇单词太长,可采用缩写,选择顺序如下

a) 首选在命名规范“常用缩写”中列示的缩写。

b) 行业约定被广泛接受的缩写。

c) 元音字母剔除法生成的缩写,缩写后长度应控制在5个字符以内,大写表示,但需在项目词汇表列

示。

1.3 对表的命名

1) 表以名词或名词短语命名,确定表名是采用复数还是单数形式,此外给表的别名定义简单规则(比方说,如果表名是一个单词,别名就取单词的前4 个字母;如果表名是两个单词,就各取两个单词的前两个字母组成4 个字母长的别名;如果表的名字由3 个单词组成,从头两个单词中各取一个然后从最后一个单词中再取出两个字母,结果还是组成4 字母长的别名,其余依次类推)

对工作用表来说,表名可以加上前缀WORK_ 后面附上采用该表的应用程序的名字。在命名过程当中,根据语义拼凑缩写即可。注意:将字段名称会统一成大写或者小写中的一种,故中间加上下划线。

举例:

基本方法: 业务分类+表实体+可选的后缀

Train _Exam_Result 培训考试分值表

Train_Exam_Student 培训考试学生信息表

Train 表示培训业务的分类,Exam表示考试实体,Result表示考试计划实体计划的后缀

2) 如果表或者是字段的名称仅有一个单词,那么建议不使用缩写,而是用完整的单词。

举例:

定义的缩写 Material Ma 物品;

物品表名为:Material, 而不是 Ma.

但是字段物品编码则是:Ma_ID;而不是Material_ID

3) 所有的存储值列表的表前面加上前缀Z

目的是将这些值列表类排序在数据库最后。

4) 所有的冗余类的命名(主要是累计表)前面加上前缀X

冗余类是为了提高数据库效率,非规范化数据库的时候加入的字段或者表

5) 关联类通过用下划线连接两个基本类之后,再加前缀R的方式命名,后面按照字母顺序罗列两个表名或者表名的缩写。

关联表用于保存多对多关系。

如果被关联的表名大于10个字母,必须将原来的表名的进行缩写。如果没有其他原因,建议都使用缩写。 举例:表Object与自身存在多对多的关系,则保存多对多关系的表命名为:R_Object;

表 Depart和Employee;存在多对多的关系;则关联表命名为R_Dept_Emp

2. 属性(列)的命名

1) 采用有意义的列名

列名以准确表述实体属性为目的。因为在表的命名上加入了对实体业务的分类,在不发生歧义的情况下,在列名命名上可以不再添加分类前缀。表内的列要针对键采用一整套设计规则。每一个表都将有一个自动ID作为主健,逻辑上的主健作为第一组候选主健来定义;

A、如果是数据库自动生成的编码,统一命名为:PK_ID

B、如果是自定义的逻辑上的编码则用缩写加“ID”的方法命名,即“XXXX_PK_ID

C、如果键是数字类型,你可以用_NO 作为后缀;

D、如果是字符类型则可以采用_CODE 后缀

E、对列名应该采用标准的前缀和后缀。

举例:销售订单的编号字段命名:Sal_Ord_ID

如果还存在一个数据库生成的自动编号,则命名为:PK_ID

注意:

在数据库设计时需要注意数据类型的选择,应遵循“数字优先、定长优先”原则

2) 所有的属性加上有关类型的后缀

注意,如果还需要其它的后缀,都放在类型后缀之前。

注: 数据类型是文本的字段,类型后缀TX可以不写。有些类型比较明显的字段,可以不写类型后缀。

3) 采用前缀命名

给每个表的列名都采用统一的前缀,那么在编写SQL表达式的时候会得到大大的简化。这样做也确实有缺点,比如破坏了自动表连接工具的作用,后者把公共列名同某些数据库联系起来。

3. 视图的命名

1) 视图以V作为前缀+有含义的命名(基本表)

命名规则和表的命名类似; 例 Vi_Customer

2) 命名应尽量体现各视图的功能。

4. 触发器的命名(尽量不使用)

基本方法:tr_+表名+功能特性含义

触发器以TR作为前缀,触发器名为相应的表名加上后缀

功能特性含义:Insert触发器加"_I",Delete触发器加"_D",Update触发器加"_U",

如:TR_Customer_I,TR_Customer_D,TR_Customer_U。

5. 存储过程名

存储过程应以'UP_'开头,和系统的存储过程区分,后续部分主要以动宾形式构成,并用下划线分割各个组成部分。

基本方法:Up_+系统名+功能特性含义

注意:Up_ 表示 user procedure

不要使用 sp_ 前缀,sp_ 在很多数据库系统中表示系统存储过程。

例:

增加代理商的帐户的存储过程为'UP_Ins_Agent_Account'。

6 序列

基本方法:seq_+功能含义名组成

7 变量名

变量名采用小写,若属于词组形式,用下划线分隔每个单词,如@my_err_no。

8命名中其他注意事项

1) 以上命名都不得超过30个字符的系统限制。变量名的长度限制为29(不包括标识字符@)。

2) 数据对象、变量的命名都采用英文字符,禁止使用中文命名。绝对不要在对象名的字符之间留空格。

3) 小心保留词,要保证你的字段名没有和保留词、数据库系统或者常用访问方法冲突

4) 保持字段名和类型的一致性,在命名字段并为其指定数据类型的时候一定要保证一致性。假如数据类型在一个表里是整数,那在另一个表里可就别变成字符型了。

四、附录

业务分类

按集团式架构、统一配置管理、多种业务形态、分类管理的总体目标,数据模型的命名规范按业务种类、实体/关系、子实体/明细三层进行前缀命名加以区分,例:具体规则如下:

1、一级前缀:

资产:Assets_

贸易:trad_

投资:inv_

管理:mgt_

经纪:brk_

咨询:adv_

2、二级前缀: 项目:assert_proj_ 物件:assert_prod_ 商务:assert_logis _ 租金:assert_rent_ 关系:assert_re

数据类型选择

数据类型选择应遵循“数字优先、定长优先”

原则,即在满足需求的情况下优先选择数字

或定长的字符。

一般顺序如下:

Bit

Int

Decimal

Char/datatime

Varchar: 在使用varchar类型时建议长度采用一定梯度增长,如使用varchar(50)、varchar(100)、varchar(200)、varchar(500)、varchar(1000)这样的长度限制,当本梯度长度不能满足需求时,调到下一个梯度,而不要采用在几个字符这样的处理方式。

Text/clob/blob

11

更多相关推荐:
数据库设计论文

数据库系统概论课程设计报告设计题目图书馆服务系统学生姓名学号班级指导老师日期20xx610成绩图书馆服务系统一需求分析对于每一位图书借阅用户来说有一款方便简洁的图书馆服务系统将可以为广大用户节省很多不必要的麻烦...

数据库设计

宁夏大学数学计算机学院数据库设计报告指导老师毕利专业软件工程学生李可新学号120xx242539班级09级7班20xx年6月22号实验目的熟悉数据库设计的基本方法和步骤搞清数据库设计各个阶段所要完成的任务通过该...

实验7 数据库设计

实验7数据库设计6学时实验目的与要求了解数据库设计的重要性和数据库设计在信息系统开发和建设中的核心地位掌握数据库设计方法和步骤实验任务在某个RDBMS产品上选择合适的应用系统开发工具为某个部门或单位开发一个数据...

数据库总结

1数据的类型包括三种字符类型数字类型日期类型11字符类型111char与varchar2的区别占用的内存空间char是定长如果填入字符串的长度小于设定的长度自是可变长度字符串动填充空字符Varchar2112最...

数据库设计实现与用户注册

淮海工学院计算机工程学院课程设计报告设计名称Web应用技术课程设计选题名称论坛系统的设计与实现姓名学号专业班级计算机科学与技术D计算机121系院计算机工程学院设计时间20xx102620xx1115设计地点软件...

数据库 学习总结

数据库学习总结XX班姓名学号摘要:在当今信息化的社会里,数据库可以说已经融入到我们生活的方方面面中,如交通运输、银行金融、工商企业等等。只要有大量的数据要管理或者需要有大量数据支持的工作,都要使用到数据库,它为…

数据库设计中的技巧

数据库设计中的14个技巧Author薛延明CreateDate20xx1031原始单据与实体之间的关系一对一一对多多对多的关系明确这种对应关系后对我们设计录入界面大有好处2主键与外键一般而言一个实体不能既无主键...

数据库设计与优化

数据库设计与优化一数据库结构的设计如果不能设计一个合理的数据库模型不仅会增加客户端和服务器端程序的编程和维护的难度而且将会影响系统实际运行的性能所以在一个系统开始实施之前完备的数据库模型的设计是必须的在一个系统...

bbs数据库设计说明书

JIANGXIAGRICULTURALUNIVERSITY题目学专百度贴吧数据库设计说明书院软件学院业软件工程英语二0一二年十二月目录1引言错误未定义书签11编写目的错误未定义书签12背景错误未定义书签13定义...

数据库课程设计——数据库设计部分

数据库应用课程设计数据库设计部分学号姓名项目名称仓库管理系统1创建数据库及数据表建立Test数据库存储仓库信息仓库员工信息货物信息单位信息和货物存取信息该数据库包含八张数据表即仓库基本信息表仓库仓库员工信息表仓...

关于用户权限的数据库设计

1设计思路为了设计一套具有较强可扩展性的用户认证管理需要建立用户角色和权限等数据库表并且建立之间的关系具体实现如下11用户用户仅仅是纯粹的用户用来记录用户相关信息如用户名密码等权限是被分离出去了的用户User要...

数据库设计论文模板

系统设计与开发课程名称数据库原理及其应用课程设计设计题目系统设计与开发学生姓名学号专业月目录第一章系统简介3第二章系统需求分析5第三章系统概念结构设计6第四章系统逻辑结构设计7第五章系统物理结构设计与数据库连接...

数据库设计总结(23篇)