天高地厚

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

约束与数据库对象规则、默认值的探究

Posted on 2013-01-26 10:37  天高地厚-GNU  阅读(148)  评论(0编辑  收藏  举报

约束、规则、默认值这三者在数据表中规定了数据进行操作时的限制条件。他们三者有关系也有区别,用了两天的时间研究了他们三者,总结如下。

首先让我们从关系角度来分析:

 

●浅谈约束、规则、默认值

    1、约束,约束顾名思义是限制条件的意思,其实它的作用也是如此,它是对所要进行增删改查操作的数据进行一次检查,检查这些数据是否符合我们所要约束的条件。举个例子:我们都经历过高考,考试规定考生不许带与考试无关的物品这就是一种约束。报名考试的考生可能因为某些意外没有进入考场考试,但大部分考生还是进行了考试。那么在考场内就产生了两种情况空位和非空位,这就是我们约束条件的两种情况。我们继续分析,在考生进入考场的情况中,考生在答卷之前是必须要在试卷和答题卡上填写自己的信息的,这些信息都是必须要填的因为它们唯一确定了一个考生,这里考生必须填写考生信息也就是我们所说的主键约束(主关键字约束)。接下来我们用两个表来说明下外键约束:

        

 

    那么如果我们在字段后面用Not Null规定了呢?也就是说在我们的考生信息表中的性别字段,该列是不允许为空的于是就用Not Null标识,但是如果我们不填的话呢,我们的系统就会用Default默认值约束来帮助我们天上一个值。接下来我们来看Check约束,该约束是要用条件表达式来限定所要填的数据的,如下:

  1. Create table 工资 (  
  2.   
  3.          name  char(10) primary key,  
  4.   
  5.          department  char(20) Not Null,  
  6.   
  7.          salary int not null check(salary>1000 and salary<4000)  
  8.   
  9. )  


    创建了一个表该表中有三个字段,name、department、salary,并在salary字段设置了约束条件。该表如下图:

 

     

    在表中填数据时后两个不符合条件是不正确的。

    在约束中还分为两种:字段级约束和表级约束。字段级约束是只约束其中的一列,表级约束是约束多列,它们两个的区别并不大,我们在理解时可以将表级理解为字段级,即:被约束的多列可以看做捆绑成一列,被捆绑后的字段中的两个记录是不能重复的,如:

 

    2、规则,规则顾名思义是规矩制度的意思,在进行表操作时它的作用和check约束条件是类似的,但是一个表中只有一个规则,可有多个check约束,如:

    

  1. Create table 薪水(  
  2.   
  3.        name  char(10) primary key,  
  4.   
  5.        position  char(20) Not Null,  
  6.   
  7.        salary int not null  
  8.   
  9.     )  
  10.   
  11. Create rule ru_salary  
  12.   
  13. As @salary>1000 and @salary<4000  
  14.   
  15. Go  
  16.   
  17. Exec sp_bindrule ‘ru_salary’,  ’薪水.salary’  
  18.   
  19.   Go  


     表说明如下:

    3、默认值,用法同规则,它的作用类似于Default约束,是说在表中插入数据时,如果没有指定值,默认值自动指定数据值。

接下来我们在语法上分析三者,看图:

 

       1、约束,创建方法大致有三种:

               

  1.     ——方法一:在创建表时用字句的方式创建约束  
  2.   
  3.     CREATE TABLE 表名(  
  4.   
  5.             列名数据类型,  
  6.   
  7.             ……  
  8.   
  9.            <span style="color:#009900;"CONSTRAINT 约束名 PRIMARY KEY (列名),                       ——主键约束  
  10.   
  11.             CONSTRAINT 约束名 UNIQUE (列名),                            ——唯一约束  
  12.   
  13.             CONSTRAINT 约束名 FOREIGN KEY (列名) REFERENCES 表名 (列名),  ——外键约束  
  14.   
  15.             CONSTRAINT 约束名 CHECK (检查条件)                           ——Check约束  
  16.   
  17. </span> );  
  18.   
  19.         ——方法二:在创建表时直接定义约束  
  20.   
  21.     CREATE TABLE 表名(  
  22.   
  23.  <span style="color:#009900;">           列名数据类型 NOT NULL,                                        ——非空约束  
  24.   
  25.             列名数据类型 NOT NULL PRIMARY KEY,                            ——主键约束  
  26.   
  27.             列名数据类型 NOT NULL UNIQUE,                                 ——唯一约束  
  28.   
  29.             列名数据类型 [NOT NULLREFERENCES 表名(列名),                ——外键约束  
  30.   
  31.             列名数据类型 [NOT NULLCHECK (检查条件)                         ——Check约束</span>  
  32.   
  33.     )  
  34.   
  35.        ——方法三:在创建表后,通过更改表来定义  
  36.   
  37. <span style="color:#009900;">   ALTER TABLE 表名 ALTER COLUMN 列名 SET NOT NULL;  
  38.   
  39.     ALTER TABLE 表名 ADD PRIMARY KEY (列名1,列名2…);  
  40.   
  41.     ALTER TABLE 表名 ADD UNIQUE (列名1,列名2,……);  
  42.   
  43.     ALTER TABLE 表名 ADD FOREIGN KEY(列名) REFERENCES 表名2 (列名2);  
  44.   
  45.     ALTER TABLE 表名 ADD CHECK (检查条件);  
  46. </span>  

      删除约束的语法为:ALTER TABLE 表名 DROP CONSTRAINT 约束名

    2、规则。规则的应用操作,首先要创建但只创建是不能应用的要用sp_bindrule将规则绑定到字段或自定义的数据类型上才能起作用。

             

  1.    ——创建  
  2.   
  3.  <span style="color:#009900;">   Create rule 规则名 as 条件表达式  
  4. </span>  
  5.     ——绑定  
  6.   
  7.    <span style="color:#009900;"Exec sp_bindrule ‘规则名’  , ‘表名.字段名’ | ‘数据类型’  
  8.   
  9. </span>    ——解除绑定  
  10.   
  11.   <span style="color:#009900;">  sp_unbindrule  ‘表名.字段名’ | ‘数据类型’  
  12. </span>  
  13.     ——删除规则  
  14.   
  15.     <span style="color:#009900;">DROP RULE {rule_name} [,...n]  
  16. </span>  

      3、默认值的语法和规则是类似的,只需将规则中的rule改成关键字default即可。