SQLServer之DEFAULT约束

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

DEFAULT约束添加规则

1、若在表中定义了默认值约束,用户在插入新的数量行时,假若该行没有点名数量,那么系统将默认值赋给该列,倘若我们不设置默认值,系统默认为NULL。

2、假若“默认值”字段中的项替换绑定的默认值(以不带圆括号的款型显得),则将唤起您拨冗对默认值的绑定,并将其替换为新的默认值。

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

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

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

利用SSMS数据库管理工具添加DEFAULT约束

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

图片 1

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

图片 2

3、点击保存按钮(或者ctrl+s)-》刷新表-》再一次打开表查看结果。

图片 3

当表结构已存在时

第一判断表中是否存在默认约束,假使存在则先删除默认约束再添加,倘诺不存在则直接助长。

语法:

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

图片 4

图片 5

创办表时添加默认约束

率先判断表是否选在,假设存在则先删除表再添加,假若不设有则一贯抬高。

语法:

–创制新表时添加默认约束
–数据库注解
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

图片 6

图片 7

DEFAULT约束优缺点

优点:

1、使用默认值可以削减代码量,新增多少时可以不用写新增默认值列,执行新增操作时时默认填充。

2、较有利开展总计和分析,以及方便程序逻辑操作。

缺点:

1、使用不为NULL的默认值,占用了更多的仓储空间。

 

相关文章