>

SQLServer修改数据列

- 编辑:www.bifa688.com -

SQLServer修改数据列

采用SSMS数据库管理工科具修改DEFAULT约束

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

88bifa必发唯一官网 1

2、在表设计器窗口-》选中要修改的数额列-》在列属性中找到暗中同意值绑定-》实行修改。

88bifa必发唯一官网 2

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

88bifa必发唯一官网 3

DEFAULT约束增加准则

1、若在表中定义了暗中同意值约束,用户在插入新的数目行时,假设该行未有一点点名数量,那么系统将暗许值赋给该列,固然大家不设置暗许值,系统默认为NULL。

2、要是“暗中同意值”字段中的项替换绑定的暗许值(以不带圆括号的款型展现),则将唤起您消除对暗许值的绑定,并将其替换为新的私下认可值。

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

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

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

修改数据列

在付出和生育进度中,列名的拼写错误恐怕列名的更改是索要操作数据表的,大多数场所下都以不供给修改的.

以下三种情形下我们并不可能直接修改数据列:

1、用于索引的列。 
2、用于 CHECK、FOREIGN KEY、UNIQUE 或 PENCOREIMAKugaY 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

 88bifa必发唯一官网 4

88bifa必发唯一官网 5

应用SSMS数据库管理工科具增添DEFAULT约束

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

88bifa必发唯一官网 6

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

88bifa必发唯一官网 7

3、点击保存按键(可能ctrl s)-》刷新表-》再度展开表查看结果。

88bifa必发唯一官网 8

使用SSMS数据库管理工科具修改列

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

88bifa必发唯一官网 9

2、在新开发的窗口视图中-》点击要修改的行-》能够修改列名、列类型、是不是可空、属性等-》修改实现点击保存按键(或然ctrl s)。

88bifa必发唯一官网 10

总结

1、每一种字段只好有多个私下认可约束。
2、倘诺暗许约束设置的值大于字段所允许的长度,则截取到字段允许长度。
3、不可能步向到含有IDENTITY属性恐怕TIMESTAMP的字段上。
4、假若字段的数据类型为用户自定义类型,何况已有私下认可值绑定在此数据类型上,则不相同意再一次使用暗中同意值。

 

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

接纳T-SQL脚本修改列

当表结构已存在时

88bifa必发唯一官网,首先剖断表中是或不是留存暗许约束,借使存在则先删除默许约束再增添,假诺官样文章则间接抬高。

语法:

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

88bifa必发唯一官网 11

88bifa必发唯一官网 12

修改列名

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

示例:exec sp_rename '[test1].height6','height7'; 

88bifa必发唯一官网 13

88bifa必发唯一官网 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

88bifa必发唯一官网 15

88bifa必发唯一官网 16

修改列数据类型

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

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

88bifa必发唯一官网 17

88bifa必发唯一官网 18

DEFAULT约束优瑕玷

优点:

1、使用暗中同意值能够减小代码量,新添多少时能够不用写新扩张私下认可值列,试行新扩大操作时时私下认可填充。

2、较实惠开始展览总括和解析,以及便于程序逻辑操作。

缺点:

1、使用不为NULL的暗中同意值,占用了更加多的仓库储存空间。

 

修改列是还是不是可空

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

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

88bifa必发唯一官网 19

88bifa必发唯一官网 20

修改列私下认可值

假使默许值不设有

语法:alter table 数据库名.dbo.表名 add constraint 约束名 default 暗中认可值 for 列名;

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

88bifa必发唯一官网 21

88bifa必发唯一官网 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;

88bifa必发唯一官网 23

总结

在付出依然生产数据库中,数据列一经济建设好,不要随便改变,随便更改或许会挑起数据库的级联操作失利和代码错误。

 

本文由88bifa必发唯一官网发布,转载请注明来源:SQLServer修改数据列