SQL SERVER 2005中,约束,Constraints,顾名思义,就是按照约定来束缚某种东西。在数据库,无非就是对存储的数据进行束缚,当然需要按照某种既定的规则,一般是指语义的限制以及用来制约属性上的关系。可能在平时的工作中,尤其是对开发人员来说,约束用的不是很多,更多的时候是用代码去做一些输入的验证,这其实就是约束的思想,把不满足条件的数据排除在外。其实SQL SERVER 2005也给我们提供这样的一些约束:
insert into Goods values(2000) (1 row(s) affected) 成功
insert into Goods values(200) ERROR:The INSERT statement conflicted with the CHECK constraint "chkPrice". The conflict occurred in database "AdventureWorks", table "dbo.Goods", column 'Price'.
这里顺便提一下,如果我们执行了下面的代码,结果会是怎样呢?
insert into goods values(null)
如果你觉得也会报错,那么恭喜你,你错了。约束其实是对满足条件,即条件表达式返回TRUE的一律通过。那么,如果结果是NULL呢?NULL在SQL SERVER里的类型是UNKNOWN,就是不知道。那我们就要把它理解成可以成为任何类型,可能为TRUE。所以在这个例子中,NULL是可以被插入的。
Create Table Users(
UserID int primary key,
UserName varchar(50) not null
)
下面是对多列设置主键:
CREATE TABLE KeyData
(
FiscalYear int not null,
Period int not null,
DataType int not null,
KeyValue int not null
CONSTRAINT [PK_constraint_keydata] PRIMARY KEY CLUSTERED
(
FiscalYear,
Period
)
)