修改MS Server 数据表脚本

修改MS Server 数据表脚本

使用T-SQL脚本添加外键约束

利用T-SQL脚本添加DEFAULT约束

CHECK约束优缺点

优点:

① 、保险列数据标准和界定,可以约束数据完整性

② 、有Check约束的列能够提要求查询优化器消息之所以升级品质

缺点:

一 、插入大概修改时数据不符合约束规则,不可能修改成功。

10:重命名表

当表结构已存在时

设若要加上约束的表已存在外键约束,需求先删除外键约束再添加外键约束。假设不设有外键约束能够拉长外键约束。

语法:

if exists(select * from sysobjects where
name=约束名)
alter table 数据库名.[dbo].表名 drop
constraint 约束名;
alter table 数据库名.[dbo].表名 with
check add constraint 约束名 foreign key(列名)
references 数据库名.[dbo].表名(列名)

on delete cascade
on update cascade;
go

示例:

if exists(select * from sysobjects where
name=’t1_t2′)
alter table [testss].[dbo].[test1]
drop constraint t1_t2;
alter table [testss].[dbo].[test1]
with check add constraint t1_t2 foreign key(classid)
references
[testss].[dbo].[test2](id)
on delete cascade
on update cascade;
go

图片 1

行使SSMS数据库管理工具添加DEFAULT约束

① 、连接数据库,选拔数据表-》右键点击-》选拔设计。

图片 2

贰 、在表设计窗口中-》接纳数据列-》在列属性窗口中找到暗中同意值或绑定-》输入暗中同意值(注意默许值的数据类型和输入格式)。

图片 3

③ 、点击保存按钮(也许ctrl+s)-》刷新表-》再次打开表查看结果。

图片 4

CHECK约束添加规则

① 、CHECK
约束用于限制列中的值的范围。

② 、Check约束通过逻辑表明式来判定数据的立见成效,用来限制输入一列或多列的值的界定,在列中立异数据时,所要输入的剧情必须满足Check约束的准绳,不然将不只怕正确输入。

三 、假诺对单个列定义 CHECK
约束,那么该列只同意特定的值。

肆 、倘诺对1个表定义 CHECK
约束,那么此约束会在一定的列中对值实行限定。

1:向表中添加字段

FOREIGN KEY约束添加规则

一 、外键约束并不仅仅能够与另一表的主键约束相链接,它还足以定义为引用另二个表中
UNIQUE 约束的列。

② 、假如在 FOREIGN
KEY 约束的列中输入非 NULL
值,则此值必须在被引用列中存在;否则,将回来违反外键约束的错误消息。 若要确定保证验证了咬合外键约束的兼具值,请对拥有加入列内定NOT NULL。

三 、FOREIGN KEY
约束仅能引用位于同一服务器上的一律数据库中的表。 跨数据库的引用完整性必须透过触发器完结。

④ 、FOREIGN KEY
约束可援引同一表中的其余列。 此行为称作自引用。

伍 、在列级钦赐的
FOREIGN KEY 约束只好列出三个引用列。 此列的数据类型必须与概念约束的列的数据类型相同。

六 、在表级钦赐的
FOREIGN KEY 约束所享有的引用列数目必须与约束列列表中的列数相同。 每一种引用列的数据类型也必须与列表中相应列的数据类型相同。

柒 、对于表可包括的引用别的表的 FOREIGN KEY
约束的数目或别的表所拥有的引用特定表的 FOREIGN KEY 约束的数码, 数据库引擎 都没有预订义的限量。 固然如此,可应用的 FOREIGN KEY
约束的实在多少依然受硬件配备以及数据库和应用程序设计的范围。 表最多能够将 25一个其他表和列作为外键引用(传出引用)。 SQL
Server 2016 (13.x) 将可在独立的表中引用的任何表和列(传入引用)的数目限制从
253 进步至 10,000。 (包容性级别至少必须为
130。)数量限制的增高带来了下列约束:

DELETE 和 UPDATE
DML 操作援救胜出 253 个外键引用。 不支持ME凯雷德GE 操作。

对自个儿进行外键引用的表仍只可以举办 25三个外键引用。

列存储索引、内存优化表和 Stretch Database
暂不支持开始展览超越 253 个外键引用。

八 、对于暂且表不强制 FOREIGN KEY 约束。

玖 、假设在 CL索罗德用户定义类型的列上定义外键,则该类型的兑现必须协理二进制排序。

⑩ 、仅当 FOREIGN
KEY
约束引用的主键也定义为品种 varchar(max) 时,才能在此约束中动用项目为varchar(max) 的列。

DEFAULT约束优缺点

优点:

一 、使用暗许值能够减掉代码量,新增多少时方可不用写新增暗中同意值列,执行新增操作时时暗中同意填充。

二 、较有利开始展览总计和分析,以及福利程序逻辑操作。

缺点:

① 、使用不为NULL的暗许值,占用了越多的储存空间。

 

行使SSMS数据库管理工科具添加CHECK约束

1、连接数据库,选拔数据库,选拔数据表-》右键点击(大概直接点击约束,右键点击,选拔丰裕约束,前面步骤一样)-》选用设计。

图片 5

二 、接纳要加上约束的数额列-》右键点击-》选择CHECK约束。

图片 6

③ 、在CHECK约束弹出框中式点心击添加。

图片 7

四 、在CHECK约束弹出框中-》输入CHECK约束表明式-》输入CHECK约束名-》输入CHECK约束描述-》别的能够选拔暗中认可。

图片 8

伍 、点击关闭-》点击保存按钮(也许ctrl+s)-》刷新表查看结果。

图片 9

11:重命名列名

行使SSMS数据库管理工科具添加外键约束

本示例演示当表结构已存在时添加外键约束,创造表时充杰出键约束步骤和表结构存在时添加外键步骤一样。示例演示如下:

壹 、连接数据库,打开要添加外键的数据表-》右键点击-》选择设计。

图片 10

贰 、在表设计窗口-》选用要添加外键的数额行-》右键点击-》选择事关。

图片 11

③ 、在外键关系窗口中-》点击添加。

图片 12

④ 、添加达成后-》首先修改表和列规范。

图片 13

5、在表和列窗口中-》输入外键名-》在左手选取主表和涉及的列-》在右手选用从表和作为外键的列-》点击鲜明。

图片 14

六 、在外键关系窗口中-》可挑选丰裕只怕不添加外键描述-》可选用丰富大概不添加修改可能去除数据时级联操作-》可挑选丰硕大概不添抓实制外键约束-》可选用丰富可能不添加强制用于复制-》点击关闭。

图片 15

柒 、点击保存按钮(ctrl+s)-》此时表会弹出警告窗口,点击是-》刷新查看外键是或不是丰硕成功。

图片 16

图片 17

DEFAULT约束添加规则

① 、若在表中定义了暗中认可值约束,用户在插入新的数目行时,若是该行没有点名数量,那么系统将暗中认可值赋给该列,假若大家不安装默许值,系统暗许为NULL。

贰 、假设“暗中同意值”字段中的项替换绑定的暗中认可值(以不带圆括号的样式显得),则将唤起您解除对暗许值的绑定,并将其替换为新的暗许值。

③ 、若要输入文本字符串,请用单引号 (‘)
将值括起来;不要选拔双引号
(“),因为双引号已保存用于带引号的标识符。

④ 、若要输入数值默许值,请输入数值并且不要用引号将值括起来。

伍 、若要输入对象/函数,请输入对象/函数的名称并且毫不用引号将名称括起来。

当表结构存在时

添加CHECK约束时首先校验约束是还是不是已存在,假诺存在应该是先删除再添加,假诺不设有则从来抬高。

语法:

— 添加3个暗许约束
use 数据库名;
go

if exists(select * from sysobjects where
name=约束名)
alter table 表名 drop constraint
约束名;
go

alter table 表名 add constraint 约束名
check(约束规则),constraint 约束名 check(约束规则);
go

示例:

— 添加二个私下认可约束
use testss;
go

if exists(select * from sysobjects where
name=’check1′)
alter table test1 drop constraint
check1;
go

alter table test1 add constraint check1
check(height>=170 and height<=175);
go

 图片 18

图片 19

Alter table [表名] alter column [列名] 类型

FOREIGN KEY约束优缺点

优点:

一 、有限支撑数据的一致性,完整性,更牢靠。

② 、关联合检查询时,能够用到FK 的总括音讯。

③ 、有主外键的数据库设计能够追加E君越图的可读性。

缺点:

壹 、删队或更新关联数据时须要做检讨,成效会非常的低。

二 、手工业调数据时,会设有主从表校验,会相比较费心。

叁 、批量导入数据时,会设有外键校验,须要先关闭外键约束,导入完毕再打开外键约束,操作相比较辛苦。

 

当表结构已存在时

率先判断表中是还是不是留存暗许约束,假诺存在则先删除私下认可约束再添加,借使不设有则一向抬高。

语法:

use 数据库
go
–判断暗中同意约束是或不是存在,尽管存在则先删除,如若不设有则平昔助长
if exists(select * from sysobjects where
name=约束名)
alter table 表名 drop constraint
约束名;
go
–给钦定列添加暗中同意约束
alter table 表名 add constraint 约束名
default(约束值) for 列名;
go

示例:

use [testss]
go
–判断暗许约束是还是不是存在,借使存在则先删除,假使不设有则平素抬高
if exists(select * from sysobjects where
name=’defalut_height’)
alter table [testss].[dbo].[test1]
drop constraint defalut_height;
go
–给钦定列添加暗中认可约束
alter table [testss].[dbo].[test1]
add constraint defalut_height default(160) for height;
go

图片 20

图片 21

当表结构不设有时

即使表结构不存在,能够直接助长约束,能够而且加上3个依旧多少个约束。

语法:

–若是表结构不设有时添加check约束
use 数据库名;
go
–借使已存在表则删除
if exists(select * from sysobjects where
name=表名 and xtype=’U’)
drop table 表名;
go
–创建表
create table 表名
(
–字段注解
列名 int identity(1,1) not null,
列名 nvarchar(50) null,
列名 nvarchar(50) null constraint 约束名
check(约束规则),
列名 nvarchar(50) null,
列名 int,
列名 int constraint 约束名
check(约束规则)
primary key clustered(列名 asc)
with(ignore_dup_key=off) on [primary], –主键索引表明
)on [primary]

–字段注释评释
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列描述’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

go

示例:

–如若表结构不存在时添加check约束
use testss;
go
–假使已存在表则删除
if exists(select * from sysobjects where
name=’test1′ and xtype=’U’)
drop table test1;
go
–创建表
create table test1
(
–字段注解
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null constraint check1
check(sex=’男’ or sex=’女’),
age nvarchar(50) null,
classid int,
height int constraint check2
check(height>=110 and height<=120)
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary], –主键索引证明
)on [primary]

–字段注释注脚
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’id主键’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’id’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’姓名’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’name’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’性别’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’sex’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’年龄’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’age’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’班级id’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’classid’;

go

 图片 22

图片 23

图片 24

16:删除表中列UserName的讲述属性:
EXEC sp_dropextendedproperty
‘MS_Description’,’user’,dbo,’TABLE’,’表名’,’column’,’Username’

在新表中开创外键

 语法:

if exists( select * from sysobjects where
name=表名 and type =’U’)
drop table 表名;
go

–当表结构不存在时
–建表语法评释
create table 表名
(
–字段注脚
列名 int identity(1,1) not null,
列名 int,
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary], –主键索引声明
constraint 外键名 foreign key(列名)

references 主表名(列名)
on update cascade–是还是不是级联操作
on delete cascade
)on [primary]

–字段注释注明
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

go

示例:

if exists( select * from sysobjects where
name=’test1’and type =’U’)
drop table test1;
go

–当表结构不设有时
–建表语法证明
create table test1
(
–字段注脚
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null,
age nvarchar(50) null,
classid int,
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary], –主键索引注脚
constraint t3_t4 foreign key(classid)

references test2 (id)
on update cascade
on delete cascade
)on [primary]

–字段注释申明
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’id主键’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’id’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’姓名’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’name’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’性别’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’sex’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’年龄’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’age’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’班级id’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’classid’;

go

图片 25

成立表时添加默许约束

率先判断表是还是不是选在,固然存在则先删除表再添加,若是不设有则一向抬高。

语法:

–成立新表时添加暗中认可约束
–数据库注明
use 数据库名
go
–借使表已存在则先删除表再创设,假若表不设有则向来开立
if exists(select * from sysobjects where
name=表名 and type =’U’)
drop table 表名;
go
–建表语法注脚
create table 表名
(
–字段申明
列名 列类型 identity(1,1) not
null,
列名 列类型) null,
列名 列类型 null,
列名 列类型 null,
列名 列类型,
列名 列类型 constraint 约束名 default
默认值,
primary key clustered(列名 asc)
with(ignore_dup_key=off) on [primary] –主键索引表明
)on [primary]

–字段注释注解
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

go

示例:

–创设新表时添加暗中认可约束
–数据库注脚
use testss
go
–假如表已存在则先删除表更创造,假设表不设有则直接创制
if exists(select * from sysobjects where
name=’test1′ and type =’U’)
drop table test1;
go
–建表语法证明
create table test1
(
–字段注明
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null,
age nvarchar(50) null,
classid int,
height int constraint default_he default
166,
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary] –主键索引评释
)on [primary]

–字段注释注脚
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’id主键’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’id’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’姓名’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’name’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’性别’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’sex’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’年龄’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’age’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’班级id’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’classid’;

go

图片 26

图片 27

运用T-SQL脚本添加CHECK约束

15:更新表中列UserName的描述属性:
EXEC sp_updateextendedproperty
‘MS_Description’,’新的姓名’,’user’,dbo,’TABLE’,’表名’,’column’,’UserName’

 Alter table [表名] add constraint [约束名]  foreign key(列名)
referencese 另一表名(列名)

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图