SQLServer修改数据列

动用SSMS数据库管理工科具改正DEFAULT限定

1、连接数据库、接受数据表-》右键点击-》采用设计。

图片 1

2、在表设计器窗口-》选中要修正的数额列-》在列属性中找到暗中认可值绑定-》进行改变。

图片 2

3、点击保存(也许ctrl+s)-》关闭表设计器-》刷新表-》重新展开表设计器查看。

图片 3

DEFAULT节制加多法规

1、若在表中定义了暗许值限制,客户在插入新的数码行时,假设该行未有一点点名数量,那么系统将暗许值赋给该列,如若大家不设置默许值,系统默以为NULL。

2、假如“暗中认可值”字段中的项替换绑定的默许值(以不带圆括号的花样体现卡塔 尔(阿拉伯语:قطر‎,则将唤起您解除对默许值的绑定,并将其替换为新的私下认可值。

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

4、若要输入数值暗中同意值,请输入数值并且不要用引号将值括起来。

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

修正数据列

在支付和临盆进度中,列名的拼写错误大概列名的改变是须要操作数据表的,大好些个场合下都以不须要修改的.

以下三种景况下大家并不可能间接校勘数据列:

1、用于索引的列。 
2、用于 CHECK、FOREIGN KEY、UNIQUE 或 PRAV4IMA哈弗Y KEY 节制的列。 
3、与私下认可值(由 DEFAULT 关键字定义卡塔 尔(阿拉伯语:قطر‎相关联的列,或绑定到暗许对象的列。 
4、绑定到法规的列。 

选用T-SQL脚本改善DEFAULT节制

DEFAULT节制定正准绳必得首先删除现成的DEFAULT节制,然后使用新定义再一次创造,技巧运用Transact-SQL改过DEFAULT节制。

语法:

–使用数据库
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=’default1′)
alter table test1 drop constraint
default1;
go
–加多默许值限制
alter table test1 add constraint default2
default 18 for age;
go

 图片 4

图片 5

动用SSMS数据库处理工具增多DEFAULT限制

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

图片 6

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

图片 7

3、点击保存开关(恐怕ctrl+s)-》刷新表-》再一次展开表查看结果。

图片 8

动用SSMS数据库管理工科具改进列

1、连接数据库,张开要改正的数据库,选用数据表-》右键点击-》选取设计。

图片 9

2、在新开垦的窗口视图中-》点击要改良的行-》能够改进列名、列类型、是或不是可空、属性等-》改过产生点击保存开关(大概ctrl+s)。

图片 10

总结

1、各类字段只好有一个默许限制。
2、要是暗许约束设置的值大于字段所允许的长短,则截取到字段允许长度。
3、无法投入到含有IDENTITY属性恐怕TIMESTAMP的字段上。
4、若是字段的数据类型为顾客自定义类型,况且本来就有暗许值绑定在那数据类型上,则区别意再一次使用私下认可值。

 

行使T-SQL脚本增添DEFAULT约束

使用T-SQL脚本改进列

当表结构已存在时

率先决断表中是不是留存暗中同意节制,假若存在则先删除暗中认可节制再增添,尽管不设有则一贯抬高。

语法:

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

图片 11

图片 12

改善列名

语法:exec sp_rename 
表明.旧列名,新列名; 

示例:exec sp_rename
‘[test1].height6′,’height7’; 

图片 13

图片 14

创建表时加多暗中同意约束

第生龙活虎剖断表是不是选在,即使存在则先删除表再增加,假诺不设有则直接助长。

语法:

–创制新表时增加私下认可约束
–数据库评释
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

图片 15

图片 16

修改列数据类型

语法:alter table 数据库名.dbo.表名 alter
column 列名 类型 [约束];  

示例:alter table [testss].dbo.[test1]
alter column height7 int null;  

图片 17

图片 18

DEFAULT约束优劣势

优点:

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

2、较有利开展计算和深入分析,以至方便程序逻辑操作。

缺点:

1、使用不为NULL的私下认可值,占用了越来越多的寄存空间。

 

改过列是不是可空

语法:alter table 数据库名.dbo.表名 alter
column 列名 类型 约束;  

示例:alter table [testss].dbo.[test1]
alter column height7 int not null;

图片 19

图片 20

校订列暗中认可值

设若私下认可值不设有

语法:alter table 数据库名.dbo.表名 add
constraint 节制名 default 默许值 for 列名;

示例:alter table [testss].dbo.[test1]
add constraint df_h default 1 for height7;

图片 21

图片 22

假设暗许值存在

语法:

–首先步决断暗中同意值否存在,假如存在就删除,若是不真实则不删除
if exists (select * from
sys.check_constraints where object_id = object_id(私下认可值限制名) and
parent_object_id = object_id(表名))
alter table 表名 drop constraint
暗中同意值约束名

–次之步增加暗中同意值

alter table 表名 add constraint  约束名
default 默认值 for 列名;

示例:

–首先步决断节制是或不是留存,假设存在就删除,如若海市蜃楼则不删除
if exists (select * from
sys.check_constraints where object_id = object_id(‘df_h’) AND
parent_object_id = object_id(‘[testss].dbo.[test1]’))
alter table [testss].dbo.[test1] drop
constraint df_h

–次之步增加暗许值

alter table [testss].dbo.[test1] add
constraint df_h default 2 for height7;

图片 23

总结

在开拓依然生产数据库中,数据列生龙活虎经济建设好,不要狂妄退换,随便退换可能会唤起数据库的级联操作战败和代码错误。