澳门金莎娱乐手机版 数据库 1、用于索引的列,才能使用Transact-SQL修改DEFAULT约束

1、用于索引的列,才能使用Transact-SQL修改DEFAULT约束



利用SSMS数据库管理工科具修正DEFAULT约束

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

澳门金莎娱乐手机版 1

2、在表设计器窗口-》选中要更正的数码列-》在列属性中找到私下认可值绑定-》举办更改。

澳门金莎娱乐手机版 2

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

澳门金莎娱乐手机版 3

DEFAULT约束增多准则

1、若在表中定义了默许值节制,顾客在插入新的数目行时,借使该行未有一点名数量,那么系统将私下认可值赋给该列,假若我们不安装暗中认可值,系统默感到NULL。

2、要是“默认值”字段中的项替换绑定的暗中同意值(以不带圆括号的情势显得卡塔尔国,则将唤起您解除对暗许值的绑定,并将其替换为新的私下认可值。

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

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

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

矫正数据列

在支付和生育进度中,列名的拼写错误或许列名的改革是内需操作数据表的,大相当多处境下都以不须要改过的.

以下两种情景下大家并不能够直接改换数据列:

1、用于索引的列。 
2、用于 CHECK、FOREIGN KEY、UNIQUE 或 P奥迪Q5IMA奥迪Q5Y 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

总结

在付出还是临盆数据库中,数据列生机勃勃经济建设好,不要专擅改换,随便改革恐怕会孳生数据库的级联操作失利和代码错误。

 

标签:

发表评论

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

相关文章

网站地图xml地图