SQLServer之DEFAULT约束

作者: 联系我们  发布:2019-10-11

DEFAULT约束增多准绳

1、若在表中定义了默许值约束,客户在插入新的数量行时,若是该行未有一点名数量,那么系统将暗许值赋给该列,假若大家不安装暗中同意值,系统默感觉NULL。

2、若是“暗中同意值”字段中的项替换绑定的暗许值(以不带圆括号的花样显得),则将唤起您清除对私下认可值的绑定,并将其替换为新的暗中同意值。

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

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

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

选用SSMS数据库管理工科具加多DEFAULT约束

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

图片 1

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

图片 2

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

图片 3

选取T-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='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的默许值,占用了更加的多的仓储空间。

 

本文由全球彩票历史版本发布于联系我们,转载请注明出处:SQLServer之DEFAULT约束

关键词:

上一篇:没有了
下一篇:免费短信平台函数说明