您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Sql 约束(1)

2025/12/3 20:15:17发布28次查看
sql 约束 讲解 2009-04-27 09:29 约束 主要包括: 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、uniq
sql 约束讲解
2009-04-27 09:29
约束主要包括:
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 constraintuniquename;
   在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               )
在sql server、orcale、ms access 支持的添加 check语法:
              create table mycheck
              (
                   id nvarchar(32) not null,
                   age int not null check (age>15 and age
              )
在sql server、orcale、ms access、my sql 都支持的添加 check 语法:
               create table mycheck
              (
                   id nvarchar(32) not null,
                   age int not null,
                   constraint checkname check (age30)
              )
在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
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product