Database Design Guidelines
Database Design Guidelines
Principles
- Support popular databases
Name Style
Table Name
Style: Pascal
Example: Employee
It is fine that you may use the singular style or plural style. But singular style is preferred here.Column Name
Style: Pascal
Example: HouseAddress
Avoid to repeat table name in the column name, for example, For table 'Employee', use 'Name' for the column of employee name.Primary Key Name
Style: Pascal, PK_${TableName}
Example: PK_EmployeeIndex Name
Style: Pascal, UK_\({Column1Name}_\){Column2Name} for unique indexes.
Use IK_\({Column1Name}_\){Column2Name} for non-unique indexes.
Example: UK_CodeForeign Key Name
Style: Pascal, FK_\({Column1Name}_\){Column2Name}
Example: FK_DepartmentId
Columns
Text columns
- Do use unicode data type to define text columns.
- Do use nvarchar for variable length text columns.
Date/Date Time
- If the value of a date column is expected to present same text result among different time zone, use numeric or text data type to define date/date-time columns.
If we define a column with date data type, default, most program language will use date-time type to store values from the column, we should realize the date value will be changed when the data is transited to a different time-zone. For example:
2001/01/15, On the database server, timezone is +8.
2001/01/15, On the application server, timezone is +8.
2001/01/15 01:00:00, On the client, timezone is +9.
So if it is a problem to you, try to use a integer or text data type to store the value.
Tips: consider the case carefully. ask these questions:
If your application will be used in different time-zone?
If you only use date part for the column?
If you only use time part for the column?
Nullable
Avoid to define a column as nullable.
Avoid to use null would reduce programing bugs, and bring better performance.Do Not use null for numeric columns if it has same meaning as zero.
Do Not use null for text columns if it has same meaning as empty.
May use null in a reference column provide that null is acceptable.
Keys
Primary Keys
- Do create a primary key for any tables.
- Recommend to use one column for the primary key.
- Use '${TableName}Id' for the name of the primary key column, the column is denoted as 'Id' columns.
- Recommend to use integer data type for the primary key column.
- Avoid change the value of the primary key column after created.
- It is acceptable to show the the value of the primary key column to customers if need.
Foreign Keys
- Do create a foreign key if there is a relation between 2 tables.
It is useful to keep data integrity. - Carefully use delete cascade clause when creating the foreign keys relationship.
Tips: Be careful, Use delete cascade is also dangerous. consider it twice before use it.
Database-specific constraints
- Avoid to use reversed words for name of objects of databases
Tips: please read the reversed words from database you will use
- Avoid to use system prefix in your object names
- Check length limitation of object names of databases
Tables
Entity Tables
Like departments, employee etc, we store these kind of information into entity tables.
In most case, the table like:
- Definition sample
Employee {EmployeeId, Code, Name, DepartmentId, ...}.
If in your system, an employee only exists in one department, you may use above definition.
Tree Tables
Like most organization, departments will be constructed as a tree, there are some top level departments (or is a root department), except these top level departments, departments must have one and only have one parent department.
We define this kind of table as:
- Definition sample
Department{DepartmentId, Code, Name, **ParentId**, ...}.
In most case, for the usage convenience, we will define a tree table for each tree relationship, denoted as a tree table.
- Definition sample
DepartmentTree{ParentId, ChildId}.
For a parent department, The table stores itself and all its descendants.
From a view of a child department, the table stores itself and all its ancestors.
Hierarchical Tables
Different as tree tables, in the hierarchical tables, a child would have 0 to n parents.
For example, groups and users:
Rules
- an user would exists in multiple groups.
- an groups would exists in multiple groups.
Definition sample
User(userId, Name, isGroup)
GroupUser(parentId, userId)
GroupUserTree(parentId, userId)
The table GroupUser stores the direct relationships.
Instead, the table GroupUserTRee stores the redundant relationships like tree tables above.
Database Design Guidelines的更多相关文章
- [书籍]重温《Framework Design Guidelines》
1. 前言 最近重温了<Framework Design Guidelines>. <Framework Design Guidelines>中文名称为<.NET设计规范 ...
- 数据库设计(二)Introduction to Database Design
原文链接:http://www.datanamic.com/support/lt-dez005-introduction-db-modeling.html Introduction to Databa ...
- Test Design Guidelines for Reusability
Last Updated: JAN.10.2008 From: http://safsdev.sourceforge.net/sqabasic2000/TestDesignGuidelines.htm ...
- Dynamic Library Design Guidelines
https://developer.apple.com/library/mac/documentation/DeveloperTools/Conceptual/DynamicLibraries/100 ...
- SAP成都C4C小李探花:浅谈Fiori Design Guidelines
Jerry: 我和周帅认识不久,自去年7月SAP成都研究院Cloud for Customer(以下简称为C4C)开发团队组建至今,根据这段时间和周帅愉快的合作经历,我觉得如果把周帅比作我读过的小说里 ...
- database design three form
https://www.cnblogs.com/linjiqin/archive/2012/04/01/2428695.html
- Database Design for Sexbale Forum
Mars March 17, 2015
- API Design
REST API Design Guidelines V 1.0.201208 Draft 5 Last Updated: 08/31/2012 1 简介 本文档旨在规范REST API的 ...
- 【DB】database introduction
database applications: – Banking System,– Stock Market,– Transportation,– Social Network,– Marine Da ...
随机推荐
- 解决IE8下opacity属性失效问题
由于opacity属性存在兼容性问题,所以在IE8下,用opacity来设置元素的透明度,会失效,从而导致页面的样式问题. 在IE8及其更早的浏览器下,我们可以使用filter属性,来代替opacit ...
- bootstrap 菜单之手风琴效果
自己用bootstrap搭了个项目,纯属娱乐....为了检验学习bootstrap之成果. 效果如图: 一.搭建中发现一问题,因为以前测试都是写的html页面,这次用了母版页,点击页面的之后,页面会刷 ...
- 实现GridControl行动态改变行字体和背景色
需求:开发时遇到一个问题, 需要根据GridControl行数据不同,实现不同的效果 在gridView的RowCellStyle的事件中实现,需要的效果 private void gridView1 ...
- ORA-01578和ORA-26040--NOLOGGING操作引起的坏块-错误解释和解决方案(文档ID 1623284.1)
ORA-01578和ORA-26040--NOLOGGING操作引起的坏块-错误解释和解决方案(文档ID 1623284.1) (一)NOLOGGING操作引起的坏块(ORA-01578和ORA-26 ...
- highchart
highchart 1 2 #下载 https://www.highcharts.com/download a. 简单例子 <!DOCTYPE html> <html lang=&q ...
- python基础——面向对象进阶
python基础--面向对象进阶 1.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 ...
- Linux磁盘分区-rpm-yum
一.磁盘分区 1.开启Linux系统前添加一块大小为15G的SCSI硬盘 2.开启系统,右击桌面,打开终端 3.为新加的硬盘分区,一个主分区大小为5G,剩余空间给扩展分区,在扩展分区上划分1个逻辑分区 ...
- spark2.1注册内部函数spark.udf.register("xx", xxx _),运行时抛出异常:Task not serializable
函数代码: class MySparkJob{ def entry(spark:SparkSession):Unit={ def getInnerRsrp(outer_rsrp: Double, we ...
- POJ-2240 Arbitrage---判断正环+枚举
题目链接: https://vjudge.net/problem/POJ-2240 题目大意: 已知n种货币,以及m种货币汇率及方式,问能否通过货币转换,使得财富增加. 思路: 由于这里问的是财富有没 ...
- ipv4与ipv6的区别
对于计算机网络有一定了解的园园们来说,对这两个概念应该比较熟悉,我也将我知道的一点点小知识分享给大家吧 1.协议使用的广泛程度不同 目前,ipv4得到了广泛的应用,基本上所以的与上网有关的(看电影,玩 ...