好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Sql约束(1)

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 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 )

在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 (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

查看更多关于Sql约束(1)的详细内容...

  阅读:35次