摘要
对于SQL Server中的约束,想必大家并不是很陌生。但是约束中真正的内涵是什么,并不是很多人都很清楚的。本文以详细的文字来介绍了什么是约束,以及如何在数据库编程中应用和使用这些约束,来达到更好的编程效果。(本文部分内容参考了SQL Server联机手册)
内容
|
数据完整性分类 |
|
实体完整性 |
|
域完整性 |
|
引用完整性 |
|
用户定义完整性 |
|
PRIMARY KEY约束 |
|
DEFAULT约束 |
|
CHECK约束 |
|
UNIQUE约束 |
|
FOREIGN KEY约束 |
正文
在数据库管理系统中,保证数据库中的数据完整性是非常重要的。所谓数据完整性,就是指存储在数据库中数据的一致性和正确性。约束定义关于列中允许值的规则,是强制完整性的标准机制。使用约束优先于使用触发器、规则和默认值。查询优化器也使用约束定义生成高性能的查询执行计划。
SQL Server联机丛书中,将数据完整性解释如下:“存储在数据库中的所有数据值均正确的状态。如果数据库中存储有不正确的数据值,则该数据库称为已丧失数据完整性。”强制数据完整性可确保数据库中的数据质量。
例如,如果输入了 employee_id 值为 123 的职员,那么该数据库不应允许其他职员使用同一 ID 值。如果计划将 employee_rating 列的值范围设定为从 1 到 5,则数据库不应接受 6。如果表有一 dept_id 列,该列存储职员的部门编号,则数据库应只允许接受公司中的有效部门编号。
数据完整性分类
在SQL Server中,根据数据完整新措施所作用的数据库对象和范围不同,可以将数据完整性分为以下几种。
SQL Server联机丛书中指明:“对表进行计划有两个重要步骤:标识列的有效值和确定如何强制列中的数据完整性。”
实体完整性
实体完整性简单的说,就是将表中的每一行看作一个实体。实体完整性要求表的标示符列或主键的完整性。可以通过建立唯一索引、PRIMARY KEY约束、UNIQUE约束,以及列的IDENTITY属性来实施实体完整性。
域完整性
域完整性是指给定列的输入有效性。要求表中指定列的数据具有正确的数据类型、格式和有效的数据范围。强制域有效性的方法有:限制类型(通过数据类型)、格式(通过 CHECK 约束和规则)或可能值的范围。域完整性通过 FOREIGN KEY 约束、CHECK 约束、DEFAULT 定义、NOT NULL 定义和规则来实现。
引用完整性
引用完整性又称参照完整性。引用完整性维持被参照表和参照表之间的数据一致性,他通过主键(PRIMARY KEY)约束和外键(FOREIGN KEY)约束来实现。引用完整性确保键值在所有表中一致。这样的一致性要求不能引用不存在的值,如果键值更改了,那么在整个数据库中,对该键值的所有引用要进行一致的更改。在被参照表中,当其主键值被其他表所参照时,该行不能被删除也不允许改变。在参照表中,不允许参照不存在的主键值。
强制引用完整性时,SQL Server 禁止用户进行下列操作:
|
当主表中没有关联的记录时,将记录添加到相关表中。 |
|
更改主表中的值并导致相关表中的记录孤立。 |
|
从主表中删除记录,但仍存在与该记录匹配的相关记录。 |
例如,对于 pubs 数据库中的 sales 和 titles 表,引用完整性基于 sales 表中的外键 (title_id) 与 titles 表中的主键 (title_id) 之间的关系。
用户定义完整性
用户定义完整性使您得以定义不属于其它任何完整性分类的特定业务规则。所有的完整性类型都支持用户定义完整性。
建立和使用约束的目的是保证数据的完整性,约束是SQL Server强制实行的应用规则,他能够限制用户存放到表中数据的格式和可能值。约束作为数据库定义的一部分在CREATE TABLE语句中声明,所以又称做声明完整性约束。约束独立于表结构,可以在不改变表结构情况下,通过ALTER TABLE语句来添加或者删除。在删除一个表时,该表所带的所有约束定义也被随之删除。
PRIMARY KEY约束
在数据库的每个表中,经常有通过一列或者多个列,唯一的标识表中的每一行。就好像我们平时使用的身份证,能够唯一的标识每个人一样。这样的一列或者多个列,被称为主键,通过主键,可以强制表的实体完整性。
每一个表中只有一个PRIMARY KEY约束,更简单的说,他是通过建立唯一索引保证指定列的实体完整性。在使用PRIMARY KEY约束时,该列的空值属性必须定义为NOT NULL,也就是说拥有主键的那一列,不能为空。
由于PRIMARY KEY约束确保唯一数据,所以经常用来定义标识列。标识列就是表中已经指派了标识属性的列。标识属性生成唯一数字。
有些刚刚开始接触SQL Server编程的技术爱好者通常会有这样的疑问,为什么非要在一个表里面建立主键?其实答案是很明显的,建立主键不仅可以保证表内数据的完整性,而且在为表建立主键的同时,Microsoft SQL Server能够通过为主键创建唯一索引强制数据的唯一性。
当在查询中使用主键时,也就是利用主键所在的列作为关键字进行查询,该所因还可以用来对数据进行快速访问。如果在PRIMARY KEY约束中未指定索引类型时,默认情况下所建立的索引为簇索引。该索引只能通过删除PRIMARY KEY约束或其相关表的方法来删除,而不能使用DROP INDEX语句删除。当PRIMARY KEY约束由另一张表的FOREIGN KEY约束引用时,不能删除PRIMARY KEY约束;要删除它,必须先删除FOREIGN KEY约束。
通常建立一列约束时,我们称之为列级PRIMARY KEY约束,应用于多列时,称之为表级PRIMARY KEY约束。
列级PRIMARY KEY约束的定义格式为:
[CONSTRAINT constraint_name] PRIMARY KEY [CLUSTERED | NONCLUSTERED] [WITH [FILLFACTOR = fillfactor]] [ON {filegroup | DEFAULT}]
|
表级PRIMARY KEY约束定义风格为:
[CONSTRAINT constraint_name] PRIMARY KEY [CLUSTERED | NONCLUSTERED] {(column[,…n])} [WITH [FILLFACTOR = fillfactor]] [ON {filegroup | DEFAULT}] |
在上面的PRIMARY KEY约束定义中,WITH子句设置为PRIMARY KEY约束所建立索引的页面填充度,ON子句指出存储索引的数据库文件组名称。将索引文件和表数据文件分寸到数据库中位于不同硬盘驱动器的数据文件中,有利于减轻单个硬盘的负载。
DEFAULT约束
使用DEFAULT约束,如果用户在插入新行是没有显示为列提供数据,系统会将默认支赋给该列。例如,在一个表的payterms列中,可以让数据库服务器在用户没有输入时填上”???”或者”fill in later”。默认值约束所提供的默认值约束所提供的默认值可以为常量、函数、系统零进函数、空值(NULL)等等。零进函数包括CURRENT_TIMESTAMP、SYSTEM_USER、CURRENT_USER、USER和SESSION_USER等。默认值约束的定义格式为:
[CONSREAINT constraint_name] DEFAULT constant_expression |
其中,constraint_name参数指出所建立的默认值约束名称。Constant_expression表达式为列提供默认值。在使用默认约束是,还应该注意以下两点:
1. |
每列只能有一个默认约束。 |
2. |
约束表达式不能参照表中的其他列和其他表、视图或存储过程。 |
CHECK约束
CHECK约束的主要作用是限制输入到一列或多列中的可能值,从而保证SQL Server数据库中数据的域完整性。例如,可以在建立用户使用库时,强制用户的密码在10位以上。每个标允许建立多个CHECK约束。在CHECK约束中可以包含搜索条件,但不能包含子查询。
同样,我们可以为表中的每个列建立约束,每个列可以拥有多个CHECK约束,但是如果使用CREATE TABLE语句,只能为每个列建立一个CHECK约束。如果CHECK约束被应用于多列时,他必须被定义为表级CHECK约束。
在表达式中,可以输入搜索条件,条件中可以包括AND或者OR一类的连接词。列级CHECK约束只能参照被约束列,而表级CHECK约束则只能参照表中列,它不能参照其他表中列。
例如,我们使用下面的语句在TB_CHECK_CONSTRAINT表中新加入一列ZIP_CODE及其相应的CHECK约束:
ALTER Table TB_CHECK_CONSTRAINT ADD ZIP_CODE char(6) null CONSTRAINT CH_ZIP_CODE check (ZIP_CODE like ‘[0-9] [0-9] [0-9] [0-9] [0-9] [0-9]’) |
同样,我们可以使用CHECK或NOCHECK来打开或者关闭某个约束。例如,下面的语句将关闭上面建立的CH_ZIP_CODE约束:
ALTER Table TB_CHECK_CONSTRAINT NOCHECK CONSTRAINT CH_ZIP_CODE |
如果希望使用编辑器来建立约束关系,需要在数据库关系图中,右击包含约束的表,然后从快捷菜单中选择“约束”命令。或者可以将包含约束的表打开表设计器,在表设计器中右击,然后选择“约束”命令。
UNIQUE约束
该约束应用于表中的非主键列,UNIQUE约束保证一列或者多列的试题完整性,确保这些猎不会输入重复的值。例如,表中UserName列为主键,但是其中还包括身份证号码列,由于所有身份证号码不可能出现重复,所以可以在此列上建立UNIQUE约束,确保不会输入重复的身份证号码。
它与PRIMARY KEY约束的不同之处在于,UNIQUE约束可以建立在多个列之上,而PRIMARY KEY约束在一个表中只能有一个。
建立UNIQUE约束,可以使用如下办法:
1. |
在数据库关系图中右击将包含约束的表,然后从快捷菜单中选择"属性"命令。 |
|
-或- |
为将包含约束的表打开表设计器,在表设计器中右击,然后从快捷菜单中选择"属性"命令。 |
2. |
选择"索引/键"选项卡。 |
3. |
选择"新建"命令。系统分配的名称出现在"索引名"框中。 |
4. |
在"列名"下展开列的列表,选择要将约束附加到的列。若要将约束附加到多个列,在后续行中选择其它的列。 |
5. |
选择"创建 UNIQUE"复选框。 |
6. |
选择"约束"选项。 |
当保存表或关系图时,唯一约束即创建在数据库中。
当希望删除UNIQUE索引时,可以使用如下步骤:
1. |
在数据库关系图中,右击包含约束列的表,然后从快捷菜单中选择"索引/键"命令。 |
|
-或- |
为包含约束的表打开表设计器,在表设计器中右击,然后从快捷菜单中选择"索引/键"命令。 |
2. |
从"选定的索引"列表中选择唯一约束。 |
3. |
选择"删除"按钮。 |
同样,对于一列的UNIQUE约束,我们称之为列级UNIQUE约束,对于多列的UNIQUE约束,我们称之为表级UNIQUE约束。下面给出列级UNIQUE约束的定义格式:
[CONSTRAINT constraint_name] UNIQUE [CLUSTERED | NONCLUSTERED] [WITH [FILLFACTOR = fillfactor]] [ON {filegroup | DEFAULT}] |
使用UNIQUE约束的过程中,还需要注意,如果要对允许空值的列强制唯一性。可以允许空值的列附加UNIQUE约束,而只能将主键的约束附加到不允许空值的列。但UNIQUE约束不允许表中受约束列有一行以上的值同时为空。
例如,下面语句为TB_UNIQUE_CONSTRAINT表添加UNIQUE约束:
ALTER Table TB_UNIQUE_CONSTRAINT ADD CONSTRAINT UN_PHONE UNIQUE (username, phone) |
FOREIGN KEY约束
FOREIGN KEY约束为表中的一列或者多列数据提供数据完整性参照。通常是与PRIMARY KEY约束或者UNIQUE约束同时使用的。
例如,在BookStores表中的author_id列以及title_id列分别参照了Authors表中的author_id列以及Titles表的title_id列。在向BookStores表中插入新行或修改其中的数据时,这两列的数据值必须在Authors表和Titles表中已经存在,否则将不能执行插入或者修改操作。
在使用FOREIGN KEY约束是,需要注意以下几点:
1. |
一个表最多只能参照253个不同的数据表,每个表也最多只能有253个FOREIGN KEY约束。 |
2. |
FOREIGN KEY约束不能应用于临时表。 |
3. |
在实施FOREIGN KEY约束时,用户必须至少拥有被参照表中参照列的SELECT或者REFERENCES权限。 |
4. |
FOREIGN KEY约束同时也可以参照自身表中的其他列。 |
5. |
FOREIGN KEY约束,只能参照本身数据库中的某个表,而不能参照其他数据库中的表。跨数据库的参照只能通过触发器来实现。 |
分享到:
相关推荐
讲解什么是数据库默认约束,示例代码演示default约束的添加和测试
通过对 SQL Server 中各种约束的理解和运用,可以有效地提高数据的一致性和准确性。主键约束确保每条记录的唯一性;唯一键约束进一步增强数据的唯一性,但允许存在空值;外键约束则用于维护不同表之间的关系,确保...
在SQL Server数据库设计中,约束是非常关键的一部分,它们用于确保数据的完整性和一致性。本实验主要探讨了在SQL Server 2012中如何创建和使用各种约束,以应用于`HumanResources.JobCandidateHistory`表。下面我们...
约束是SQL Server中用于维护数据完整性的一种核心机制。它们定义了列的取值规则,并在数据输入时自动执行这些规则。约束分为多种类型,包括 PRIMARY KEY(主键约束)用于确保表的每行都有唯一标识,DEFAULT(默认...
首先,标题中的"sqlserver自动生成sql语句工具"指的是可以分析SQL Server数据库结构和数据,自动生成对应的SQL创建语句的软件。这种工具通常能帮助数据库管理员快速获取数据库的定义,便于备份、迁移或在其他环境中...
综上所述,SQL Server连接工具是SQL Server生态系统中不可或缺的一部分,它们为数据库管理员和开发者提供了强大的支持,使得SQL Server的管理和开发工作更加高效便捷。无论是在本地环境还是云端,选择合适的工具能够...
1. **SQL Server架构**:了解SQL Server的核心组件,如数据库引擎、Analysis Services、Integration Services、Reporting Services等,以及它们在数据处理中的作用。 2. **安装与配置**:包括SQL Server的安装步骤...
"SQL Server基本图标"通常指的是该数据库系统中用于表示不同对象、状态和操作的图形元素。这些图标在数据库管理和开发过程中起着重要的可视化作用,帮助用户快速识别和理解各种元素。 1. **图标的重要性** 图标在...
以上是关于 SQL Server 中增加约束的方法及相关管理命令的详细介绍。这些命令对于数据库管理员来说是非常有用的工具,能够帮助他们有效地管理数据库结构和数据完整性。通过正确地使用这些命令,可以确保数据的安全性...
本篇文章将详细探讨如何将ORACLE数据库中的BLOB(Binary Large Object)字段导入到SQL SERVER中的IMAGE字段,这通常涉及到数据转换、数据迁移以及可能的数据类型兼容性问题。 首先,让我们了解BLOB和IMAGE字段的...
【SQLServer2000介绍】是关于微软的SQL Server 2000数据库管理系统的一份详细概述。SQL Server起源于Sybase SQL Server,由Sybase、Microsoft和Asbton-Tate公司共同开发,最初在OS/2操作系统上运行。随着技术的发展...
在你提供的链接中,博主分享了一个可能的实用工具或方法,名为“sqlserver带约束.docx”。这个文档可能包含了更详细的操作步骤或自定义脚本,用于更高效地导出SQL Server的带约束脚本。阅读这份文档将有助于你了解...
3. **数据库架构**:SQL Server 2000中的数据库由表、视图、存储过程、触发器、索引、约束等构成。表是数据的主要载体,视图是虚拟的表,存储过程是预编译的SQL语句集合,触发器用于响应特定的数据更改事件,索引...
2. **数据库结构**:SQL Server与SQLite的表结构可能存在差异,例如字段类型、主键约束、外键约束等。工具需要处理这些差异,确保转换后的SQLite数据库能正确反映原始SQL Server的结构。 3. **数据类型映射**:SQL ...
在 SQL Server 中,外键约束是用于确保数据的一致性和完整性的一个重要机制。然而,空值可能会导致外键约束的不确定性。为了解决这个问题,我们可以使用 ISNULL 函数将空值替换成一个默认值,从而避免外键约束的不...
针对这个需求,存在一种名为“SQLServer数据库表中数据导出成SQL语句工具”的实用程序,它能够帮助我们高效地完成这项任务。这个工具通常以MHT(Multi-Part/Related)格式提供,这是一种单一文件Web页面存储格式,...
- **介绍**:本实验介绍了SQL Server 2005及其管理工具——SQL Server Management Studio的基本功能。 - **学习目标**: - 创建数据库。 - 查看数据库中的对象和默认表。 - 使用查询编辑器。 - 通过多种方式...
### SQLServer SQL语法大全 #### 创建数据库 在SQL Server中创建数据库是一项基本操作,通过`CREATE DATABASE`命令来实现。创建数据库时可以指定文件和日志文件的位置、初始大小及增长方式等参数。 **语法示例:**...
在本文中,我们将详细介绍 SQL Server 2008 中的五种约束:Primary Key 约束、Foreign Key 约束、Unique 约束、Default 约束和 Check 约束。 Primary Key 约束 Primary Key 约束是 SQL Server 2008 中的一种基本...
在SQL Server中,创建表的命令是`CREATE TABLE`,这里会指定表名、字段名、字段类型及约束条件。主键用于唯一标识表中的每一行,可以用`PRIMARY KEY`约束来定义;外键则用来建立表与表之间的关联,通过`FOREIGN KEY`...