2008从入门到精通

时间:2019-11-27 23:11来源:澳洲幸运10产品
约束 主关键字节制(Primary Key Constraint卡塔尔国 用来钦点表中的一列或几列组合的值在表中具有唯生机勃勃性。创立主键的指标是让外键来引用。 Primary Key的始建情势 在创制表时创造

约束

主关键字节制(Primary Key Constraint卡塔尔国

用来钦点表中的一列或几列组合的值在表中具有唯生机勃勃性。创立主键的指标是让外键来引用。

Primary Key的始建情势

在创制表时创造Primary Key

CREATE TABLE table1(
    t_id VARCHAR(12) ,
    t_name VARCHAR(20),
    t_phone VARCHAR(20),
    CONSTRAINT t_idss PRIMARY KEY(t_id)
);

对t_id列创建主键,约束名称叫t_idss。

删除Primary Key
ALTER TABLE table1
DROP CONSTRAINT t_idss;

自律名与列名区别等,此处填写节制名

向原来就有表中增多Primary Key
ALTER TABLE table1
ADD CONSTRAINT t_idss
PRIMARY KEY(t_id);
增进Primary Key的另意气风发种示例
ALTER TABLE Products
ADD PRIMARY KEY(prod_id);

虽说上述代码运转没难题,查看表格设计也足以看看Primary Key设置成功,不过在剔除Primary Key操作时会提示:
消息3728,级别16,状态1,第1 行
'prod_id' 不是节制。
消息3727,级别16,状态0,第1 行
不能够删除约束。请参阅前边的错误信息。
原因是增进Primary Key语句中从不用CONSTRAINT指明节制名,系统自动生成了主键名和平条节制名,要先查看主键名和平条节制名,删除时填写的也是节制名。
这种气象的准确删除方法

ALTER TABLE Products
DROP CONSTRAINT CK__Products__prod_p__1A14E395;
ALTER TABLE Products
DROP CONSTRAINT PK__Products__56958AB222AA2996;
多列组合增多主键限定
CREATE TABLE table1(
    t_id VARCHAR(12),
    s_id VARCHAR(20),
    score FLOAT,
    CONSTRAINT ts_id PRIMARY KEY(t_id,s_id)
);
外关键字约束(Foreign Key Constraint卡塔 尔(阿拉伯语:قطر‎

概念了表之间的关系,用来维护七个表之间的黄金年代致性的涉嫌。
在开创表时创设Foreign Key Constraint

CREATE TABLE table2(
    s_id VARCHAR(20),
    s_name VARCHAR(12),
    s_tellphone VARCHAR(11),
    s_address VARCHAR(20),
    CONSTRAINT PK_s_id PRIMARY KEY(s_id),
);--首先新建table2,设置s_id为主键

CREATE TABLE table1(
    t_id VARCHAR(12),
    s_id VARCHAR(20),
    score FLOAT,
    CONSTRAINT pk_ts_id PRIMARY KEY(t_id,s_id),--新建table1,对t_id和s_id设置联合主键,键名pk_ts_id
    CONSTRAINT fk_s_id FOREIGN KEY(s_id)--对s_id设置外键fk_s_id
    REFERENCES table2(s_id)--外键fk_s_id外键关联table2的列s_id
    ON DELETE CASCADE--设置在table1的s_id删除时table2的s_id同时删除
    ON UPDATE CASCADE--设置在table1的s_id更新时table2的s_id同时更新
);

注:对table1设置外键关联table2,在插入数据时要求先插入table2的数额,技术得逞插入table1的多少。改过table2.s_id数据,table1.s_id数据也会自行改动。不过校正table1.s_id数据,实施时报外键冲突。总的来说对table1设置外键关联table2后,table1的数额跟着table2走,不能够反着来。

增加和删除却键约束同主键。

UNIQUE约束

除主键外另风华正茂种能够定义唯生龙活虎节制的种类,允许空值。增加UNIQUE的主意同上,这里只轻易举个例子。

USE test
GO
ALTER TABLE table2
ADD CONSTRAINT uk_s_tellphone
UNIQUE(s_tellphone);
CHECK约束

分为表限定和列限定,用于节制字段值在有个别范围。

添加CHECK约束
ALTER TABLE table2
ADD sex CHAR(2);--在table表中添加sex,数据类型为CHAR,用来存放性别
GO
ALTER TABLE table2
ADD CONSTRAINT ck_sex CHECK(sex in('男','女'));

注:那时候sex列数据类型不可能是bit,假使填写bit,只可以存款和储蓄0和1,用CHECK节制节制结果为男和女就能够报错。

在创设表的时候增多CHECK 限定
CREATE TABLE table3(
    t3_id VARCHAR(12),
    t3_name VARCHAR(20),
    t3_class VARCHAR(12),
    t3_type VARCHAR(12),
    CONSTRAINT ck_t3_type CHECK(t3_type in('类型1','类型2','类型3')) 
)

增添了节制后假使插入不切合节制的多寡

INSERT INTO table3(
    t3_id,
    t3_name,
    t3_class,
    t3_type
)VALUES(
'2018038219',
'李建',
'社会与科学',
'任何数据'
);

消息547,级别16,状态0,第1 行
INSERT 语句与CHECK 约束"ck_t3_type"冲突。该冲突时有发生于数据库"test",表"dbo.table3", column 't3_type'。
讲话已甘休。

删除CHECK约束
ALTER TABLE table3
DROP CONSTRAINT ck_t3_type;
DEFAULT约束

通过定义列的默许值或采用数据库的默许值对象绑定表列,来钦赐列的暗许值。

在建表时增加DEFAULT节制
CREATE TABLE table3(
    t3_id VARCHAR(12),
    t3_name VARCHAR(20),
    t3_class VARCHAR(12),
    t3_type VARCHAR(12) DEFAULT '类型1' 
)
删除DEFAULT约束
ALTER TABLE table3
DROP CONSTRAINT DF__table3__t3_type__3D5E1FD2;
--DF__table3__t3_type__3D5E1FD2是DEFAULT约束的约束名
丰盛封锁不点名约束名
ALTER TABLE table3
ADD DEFAULT '类型2' FOR t3_type;
GO
增加封锁钦命限制名
ALTER TABLE table3
ADD CONSTRAINT df_t3_type
DEFAULT '类型2' FOR t3_type;
GO
NOT NULL约束

自律字段值不为空。

建表时设置NOT NULL限定
CREATE TABLE table3(
    t3_id VARCHAR(12) NOT NULL,
    t3_name VARCHAR(20) NOT NULL,
    t3_class VARCHAR(12) NOT NULL,
    t3_type VARCHAR(12) NOT NULL 
)
为已存在的列增多NOT NULL节制
ALTER TABLE table3
ALTER COLUMN t3_type VARCHAR(12) NOT NULL;
删除NOT NULL约束
ALTER TABLE table3
ALTER COLUMN t3_type VARCHAR(12) NULL;
GO

自定义私下认可值对象保险数据完整性

CREATE DEFAULT date_today AS GETDATE();
--新建默认值对象名date_today,默认值为getdate()函数,获取当前日期
GO
EXEC sp_addtype date_time,'date','NULL';
--利用存储过程新建自定义数据类型date_time,参照系统数据类型date
GO
EXEC sp_bindefault 'date_today','date_time';
--将默认值对象date_today绑定到自定义数据类型date_time上
GO
CREATE TABLE table3(--新建table3,设置字段t3_date的数据类型为date_time
    t3_id VARCHAR(12),
    t3_name VARCHAR(20),
    t3_class VARCHAR(12),
    t3_type VARCHAR(12),
    t3_date date_time
);
GO
INSERT INTO table3(--为新建表table3插入一条数据,不指定t3_date的值,看默认值是否有效
    t3_id,
    t3_name,
    t3_class,
    t3_type
)VALUES(
'2018038220',
'李建',
'社会与科学',
'类型1'
);
GO
SELECT * FROM table3;--查询table3数据,看t3_date是否有默认值为当前日期

询问结果如下
图片 1

ALTER TABLE table3
ADD t3_date1 DATE;--在table3表中新增一列t3_date1,数据类型为DATE
GO
EXEC sp_bindefault 'date_today','table3.t3_date1';
--直接将默认值对象date_today绑定到table3的t3_date1列
GO
INSERT INTO table3(--为新建表table3插入一条数据,不指定t3_date和t3_date1的值,看默认值是否有效
    t3_id,
    t3_name,
    t3_class,
    t3_type
)VALUES(
'2018038221',
'李建',
'社会与科学',
'类型'
);
GO
SELECT * FROM table3;
GO

查询结果如下
图片 2

仓库储存进程查询私下认可值对象的全数者
USE test
EXEC sp_help date_today;
GO

结果如图所示
图片 3

剔除私下认可值对象
DROP DEFAULT date_today;

删去不成功,提示以下音信:
消息3716,级别16,状态3,第1 行
没辙删除暗中同意值'date_today',因为它已绑定到三个或七个列。
这正是说大家知道,当两个暗中同意值对象绑定了列其后,就无法删除它,借使想要删除,就非得先解绑。在上边的操作中,大家的暗许值对象date_today绑定了test数据库table3表的t3_date1字段。

对列解绑暗中同意值对象
USE test
GO
EXEC sp_unbindefault 'table3.t3_date1';

那时候我们再次尝试删除私下认可值对象,开掘照旧极其,那时要在意,在地方的操作中,默许值对象date_today不独有绑定了t3_date1列,还绑定了自定义数据类型date_time,并将该数据类型定义给了t3_date列,大家还必要对date_time解绑私下认可值对象。

EXEC sp_unbindefault 'date_time';

那儿再也删除暗中认可值对象,就足以成功删除。删除暗中认可值对象后,原先绑定的字段不会再有暗中认可值。

自定义准绳维护数据完整性

平整是对列或自定义数据类型的值的鲜明和限量。自定义准绳的表明式一定要重返布尔类型的值,何况表达式中不可能包涵多个变量。

CREATE RULE score_rule AS @math_score>=0;
GO--新建规则score_rule,参数@math_score
EXEC sp_addtype 'score_type','float','NULL';
GO--新建自定义数据类型score_type
CREATE TABLE table_score(--新建表table_score,预设mt_score和at_score字段用于绑定规则
s_id VARCHAR(4),
s_name VARCHAR(10),
mt_score float,--该字段将用于规则score_rule绑定到列
at_score score_type--该字段将用于规则score_rule绑定到自定义数据类型
);
GO
EXEC sp_bindrule 'score_rule','score_type';
GO--将score_rule规则绑定到自定义数据类型score_type
EXEC sp_bindrule 'score_rule','table_score.mt_score';
GO--将score_rule规则绑定到table_score表的mt_score列

----以下进行规则测试
INSERT INTO table_score(
s_id,
s_name,
mt_score,
at_score
)VALUES(
'0001',
'张华',
'-1',
'-1'
);
GO

进行违反准则的插入后,数据库报错
消息513,级别16,状态0,第1 行
列的插入或更新与原先的CREATE RULE 语句所内定的法则发生冲突。该语句已终止。冲突时有发生于数据库'test',表'dbo.table_score',列'mt_score'。
话语已结束。
很明显,mt_score的插入值为-1,违反了总得高于等于0的平整,数据库报错。将mt_score的插入值改成契合准绳的多少,再度运转插入语句,数据库依旧会报错,因为at_score字段的插入值也是违反法规的。将三个数据改成相符准则的回到,实施成功。

注:新建准绳时表明式一定倘使回来布尔类型的值,不然会报错

消息4145,级别15,状态1,过程sum_score,第1 行
在应选拔规范的上下文(在';' 周围)中内定了非布尔类型的表达式。

除去自定义准则

和自定义暗中同意值对象近似,删除自定义法则供给该准绳先与字段和自定义数据类型解绑。在上边的操作中,score_rule准绳与自定义数据类型score_type以及列mt_score已绑定。因而施行以下语句:

EXEC sp_unbindrule 'score_type';
GO--解除规则score_rule与score_type之间的绑定
EXEC sp_unbindrule 'table_score.mt_score';
GO--解除规则score_rule与表table_score的mt_score列的绑定
DROP RULE score_rule;--删除score_rule规则

注:经过考试,一个列只好绑定1条准绳,假诺对壹个列绑定2条准绳,前一条法则会被后一条准则顶替。

翻看自定义法则
EXEC sp_help 'score_rule';

结果如图所示
图片 4

翻开自定义法则的概念音信
EXEC sp_helptext 'score_rule';
GO

结果如图所示
图片 5

编辑:澳洲幸运10产品 本文来源:2008从入门到精通

关键词: