zoukankan      html  css  js  c++  java
  • SQLServer 中有五种约束, Primary Key 约束、 Foreign Key 约束、 Unique 约束、 Default 约束和 Check 约束

        一直在关注软件设计方面,数据库方面就忽略了很多,最近在设计数据库时遇到了一些小麻烦,主要是数据库中约束和性能调优方面的应用,以前在学习 Sql Server 2000,还有后来的 Sql Server 2005 数据库时进行了总结,现在也暴露出了一些问题,由于学习的不深入,有一段时间不使用,就会忘记一些东西,所以为了让自己的知识更加牢固,还是要经常拿出来,看看。

           那闲话少说进入我们今天的主题, SQLServer 中有五种约束, Primary Key 约束、 Foreign Key 约束、 Unique 约束、 Default 约束和 Check 约束,今天使用SQL Server2008 来演示下这几种约束的创建和使用的方法。


    1 、 Primary Key 约束

          在表中常有一列或多列的组合,其值能唯一标识表中的每一行。

          这样的一列或多列成为表的主键(PrimaryKey)。一个表只能有一个主键,而且主键约束中的列不能为空值。只有主键列才能被作为其他表的外键所创建。

         创建主键约束可以右键单击表,选择设计 。

         

         选中要创建主键的列,然后单击上面的小钥匙。

         

         也可以右键需要创建主键的列,然后单击小钥匙。

        
     
    2 、 Foreign Key 约束

          外键约束是用来加强两个表(主表和从表)的一列或多列数据之间的连接的。创建外键约束的顺序是先定义主表的主键,然后定义从表的外键。也就是说只有主表的主键才能被从表用来作为外键使用,被约束的从表中的列可以不是主键,主表限制了从表更新和插入的操作。

         右键单击需要设置外键的列(此时的表是作为从表在外键中出现),选择关系。

        

         接下来点击添加 --> 表和列规范。
        
        

         在主键表中选择主表和主表的主键列。

         

         设置完后保存即可。
        
     
    3 、 Unique 约束

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

         右键单击要设置的列选择索引 / 键。

        

         然后单击添加按钮。

        

         选择需要设置的列,可以是一列也可以是多列的组合。

        


         关闭并保存设置。

    4 、 Default 约束

          若在表中定义了默认值约束,用户在插入新的数据行时,如果该行没有指定数据,那么系统将默认值赋给该列,如果我们不设置默认值,系统默认为 NULL 。

          以学生信息表为例,在表设计器中,为性别 sex 列填写默认值男。

        

    5 、 Check 约束

          Check 约束通过逻辑表达式来判断数据的有效性,用来限制输入一列或多列的值的范围。在列中更新数据时,所要输入的内容必须满足 Check 约束的条件,否则将无法正确输入。

         以学生信息表中的 sex 为例,我们要限制 sex 列的值只能为男或女。

        

        

        

            

       关闭并保存设计。

  • 相关阅读:
    进程、线程和协程的图解
    Python多线程的原理与实现
    Python多进程原理与实现
    python面试题-1
    数据库事务隔离级别--读未提交,读已提交,重复读,序列化
    java--浅谈线程(二、线程的方法和状态)
    java--浅谈线程(一简单介绍)
    类加载机制--浅谈
    JSP/Servlet Web 学习笔记 DayThree
    JSP/Servlet Web 学习笔记 DayThree —— 实现一个登陆小界面
  • 原文地址:https://www.cnblogs.com/PatrickLiu/p/10607235.html
Copyright © 2011-2022 走看看