SQL约束(对比)

约束主要包括:

NOT NULL
UNIQUE
PRIMARY KEY
FOREIGN KEY
CHECK
DEFAULT

1、not null :用于控制字段的内容一定不能为空(NULL)。
     用法 :Create table MyTable
               (
                   id varchar(32) not null,
                   name varchar (32)
               )

2、Unique :控件字段内容不能重复,一个表允许有多个 Unique 约束。
      在Sql Server、Orcale、MS Access 支持的添加 Unique 语法:
             Create table MyTable
                (
                    id varchar(32) not null unique,
                    name varchar (32)
                )

      在Sql Server、 My Sql 支持的添加 Unique 语法:
             Create table MyTable
                (
                    id varchar(32) not null,
                    name varchar (32),
                   unique (id,.....)
                 )

      在Sql Server、Orcale、MS Access、My Sql 都支持的添加 Unique 语法:
              Create table MyTable
                  (
                      id varchar(32) not null,
                      name varchar (32),
                     Constraint uniqueName unique(UniqueColumn,.....)
                   )

      注:第一种写法(也就是在字段后面直接添加约束),保证每个字段数据唯一性。
          第二种写法(也就是同时添加几个字段为约束),这个是保证几个字段数据同时是唯一的,比如 Unique(id,name) 两个字段为约束,那么当 id 有重复值,而 name 没有重复值的情况下是允许的,只有当两个字段数据都与原数据重复的情况下才是不允许的。
  
   在Sql Server、Oracle、MS Access 删除 Unique 约束语法:drop constraint UniqueName;
   在My Sql 删除 Unique 约束语法:drop index UniqueName;

3、Primary Key :也是用于控件字段内容不能重复,但它在一个表只允许出现一个。
      在Sql Server、Orcale、MS Access 支持的添加Primary Key语法:
              Create table myTB1
             (
                 id nvarchar(32) not null primary key,
                 name nvarchar(32)
              )
      在Sql Server、My Sql 支持的添加Primary Key 语法:
             Create table myTB1
             (
                 id nvarchar(32) not null,
                 name nvarchar(32),
                 primary key (id)
             )
       在Sql Server、Orcale、MS Access、My Sql 支持的添加Primary Key 语法:
             Create table myTB1
             (
                  id nvarchar(32) not null,
                 name nvarchar(32),
                 constraint PrimaryName primary key (id)
              )
在Sql Server、Orcale、MS Access、My Sql 表已存在的情况下,添加表的Primary Key约束语法:
              Alter table myTB1
              ADD Primary Key (id,......) --这样的写法,系统会自定义约束名称

              Alter table myTB1
              Add Constaint PrimaryName primary key (id) --这样的写法,自己可以自定义约束名称

在Sql Server、Orcale、MS Access 删除表已存在的 Primary Key 约束的语法:
              Alter table myTB1
              Drop Constraint PrimaryName

在My Sql 删除表已存在的 Primary Key 约束的语法:
              Alter table myTB1
              Drop Primary Key
Unique 与 Primary 的相同之处:UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
Unique 与 Primary 的不同之处:每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束,Unique允许有NULL值,而 Primary key 不允许有NULL值。

注:在同一个数据库中,就算在不同的表中,约束名称是不允许相同的。

4、Foreign Key :FOREIGN KEY 约束用于预防破坏表之间连接的动作,FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
   在Sql Server、My Sql 支持的添加Foreign Key语法:
              Create table myTB1
              (
                   id nvarchar(32) not null primary key,
                   name nvarchar(32),
                   foreign key(id) references myTB(id)
              )

   在Sql Server、Orcale、MS Access 支持的添加Foreign Key语法:
              Create table myTB1
              (
                   id nvarchar(32) not null foreign key references myTB(id),
                   name nvarchar(32)
              )

   在Sql Server、Orcale、MS Access、My Sql 都支持的添加Foreign Key语法:
              Create table myTB1
              (
                   id nvarchar(32) not null primary key,
                   name nvarchar(32),
                    Constraint foreignName foreign key(id) references myTB(id)
              )

在Sql Server、Orcale、MS Access、My Sql 的表已存在情况下,向表添加外键约束的语法:
              Alter table myTB1
              Add foreign key(id) references myTB(id) --这样写系统会自定义约束名称

               Alter table myTB1
              Add Constraint foreignName foreign key(id) references myTB(id) --这样写自己可以自定义约束名称

在Sql Server、Orcale、MS Access 中删除外键约束的语法:
              Alter table myTB1
              Drop Constraint foreignName;

在My Sql 中删除外键约束的语法:
              Alter table myTB1
              Drop foreign key foreignName;


5、Check :用于控制字段的值范围。
      在Sql Server、My Sql 支持的添加check 语法:
              Create table myCheck
              (
                   id nvarchar(32) not null,
                   age int not null,
                   check (age>15 and age <30)
              )

       在Sql Server、Orcale、MS Access 支持的添加 check 语法:
              Create table myCheck
              (
                   id nvarchar(32) not null,
                   age int not null check (age>15 and age<30)
              )

      在Sql Server、Orcale、MS Access、My Sql 都支持的添加 check 语法:
               Create table myCheck
              (
                   id nvarchar(32) not null,
                   age int not null,
                   constraint checkName check (age<15 and age>30)
              )

在Sql Server、Orcale、MS Access、My Sql 的表已存在情况下,向表添加check约束的语法:
              Alter table myCheck
              add check (id='celly'); --这样定义是系统自定义 check约束名称。

              Alter table myCheck
               add constraint checkName check(id='celly'); --这样定义是自己自定义 check约束名称。

在 Sql Server、Orcale、MS Access 删除表已存在的 check 约束的语法:
              Alter table myCheck
              drop constraint checkName

6、Default :用于设置新记录的默认值。

      在Sql Server、Orcale、MS Access、My Sql 添加default约束的语法:
              Create table myDefault
              (
                  id int,
                  name nvarchar(32) default 'celly'
              )

      在My Sql 的已存在表中添加 字段默认值:
               Alter table myDefault
              Alter [id] set default 0

      在 Sql Server、Orcale、MS Access 的已存在表中添加 字段默认值:
              Alter table myDefault
              Alter column [id] set default 0

      在 My Sql 中删除字段默认值语法:
              Alter table myDefault
              Alter ColumnName drop default

 


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fancy050821/archive/2009/05/13/4176212.aspx

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值