zoukankan      html  css  js  c++  java
  • SQL Server 2008 如何查看与创建约束

    原创地址:http://www.cnblogs.com/jfzhu/archive/2012/11/23/2785269.html

    转载请注明出处

    SQL Server中有五种约束类型,分别是 PRIMARY KEY约束、FOREIGN KEY约束、UNIQUE约束、DEFAULT约束、和CHECK约束。查看或者创建约束都要使用到 Microsoft SQL Server Managment Studio。

    1. PRIMARY KEY约束

    在表中常有一列或多列的组合,其值能唯一标识表中的每一行。这样的一列或多列成为表的主键(Primary Key)。一个表只能有一个主键,而且主键约束中的列不能为空值。

    查看PRIMARY KEY约束可以在object explorer中依次展开Databases –> 选择你要查看的数据库(在我的例子中是testdatabase) –> Tables –> 你要查看的表(在我的例子中是company)-> Columns

    image

    如上图所示,Primary Key 有一把金色的小钥匙。companyid 即为company表的primary key。

    创建PRIMARY KEY约束可以右键点击表,然后选择Design,打开表设计器

    image

    选中column,点击上面的金色小钥匙,来创建Primary Key。

    image

    也可以右键点击column,然后选择Set Primary Key。

    image

    2. FOREIGN KEY约束

    外键(Foreign Key)是用于建立和加强两个表(主表与从表)的一列或多列数据之间的连接的。创建约束的顺序是先定义主表的主键,再对从表定义外键约束。

    查看FOREIGN KEY约束,展开Columns,可以看到灰色的小钥匙为Foreign Key;展开Keys,可以看到Foreign Key约束的名字为FK_contact_company。

    image

    在表设计器中,也可以点击上面的Relationships按钮,这样就可以查看到所有的Foreign Key约束

    image

    image

    上面的例子可以看到contact 表的companyid为外键,company 表的companyid为主键。

    下面来演示一下如何创建的该Foreign Key约束。

    同样是点击完Relationships按钮之后,在弹出的对话框中选择Add

    image

    然后点击下面的红色圆圈内的按钮:

    image

    按下图中那样设置主表、主键和从表、外键

    image

    然后点击 OK,不要忘记保存你的设计。

    image

    3. UNIQUE约束

    UNIQUE约束用于确保表中的两个数据行在非主键中没有相同的列值。与PRIMARY KEY约束类似,UNIQUE约束也强制唯一性,但UNIQUE约束用于非主键的一列或多列组合,且一个表可以定义多个UNIQUE约束,另外UNIQUE约束可以用于定义多列组合。

    还以company table为例,假设我们要约束company name为唯一的,点击Manage Indexes and Keys

    image

    然后点击Add来添加Unique约束

    image

    选择column为companyname, Is Unique为Yes。

    image

    关闭并保存你的设计,这样一个Unique约束就创建好了。

    4. DEFAULT约束

    若在表中某列定义了DEFAULT约束,用户在插入新的数据行时,如果该列没有指定数据,那么系统将默认值赋给该列,当然该默认值也可以是空值(NULL)。

    以contact表为例,在表设计器中,为性别(sex)列填写属性默认值 (‘M’)。

    image

    5. CHECK约束

    CHECK约束用于限制输入一列或多列的值的范围,通过逻辑表达式来判断数据的有效性。一个列的输入内容必须满足CHECK约束的条件,否则数据无法正常输入。

    还以contact表为例, 我们要限制sex列的值只能为 ´M´ 或者 ´F´。在表设计器中点击Manage Check Constraints

    image

    点击Add添加新的constraint

    image

    点击红圈内的按钮,填写表达式。我们例子中用的表达式是 SEX='M' OR SEX='F'

    image

    关闭并保存设计。向contact表中插入一行数据,如果sex列的值不为´M´ 或 ´F´, 插入就会报错。

  • 相关阅读:
    链表(一):链表简介
    PLSQL_性能优化系列14_Oracle High Water Level高水位分析
    PLSQL_性能优化系列13_Oracle Index Rebuild索引重建
    PLSQL_性能优化系列12_Oracle Index Anaylsis索引分析
    PLSQL_性能优化系列11_Oracle Bulk Collect批处理
    PLSQL_性能优化系列10_Oracle Array数据组优化
    PLSQL_性能优化系列09_Oracle Partition Table数据分区表
    PLSQL_性能优化系列08_Oracle Insert / Direct Insert性能优化
    PLSQL_性能优化系列07_Oracle Parse Bind Variables解析绑定变量
    PLSQL_批量压缩表Table Compress(案例)
  • 原文地址:https://www.cnblogs.com/SpringSmallGrass/p/3005945.html
Copyright © 2011-2022 走看看