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