美高梅游戏官网娱乐_美高梅手机登录网站

美高梅游戏官网娱乐是公司推出的企业级即时在线娱乐平台,美高梅手机登录网站业界专业、信誉最好的博彩网站,美高梅游戏官网娱乐拥有最高优惠活动和返水,拥有丰富的管理经验和专业的技术队.。

来自 数据库 2019-10-22 15:12 的文章
当前位置: 美高梅游戏官网娱乐 > 数据库 > 正文

慎选数据表-》右键点击(恐怕直接点击约束,4、

CHECK约束增多法规

1、CHECK 约束用于限制列中的值的限量。

2、Check约束通过逻辑表明式来剖断数据的有效性,用来界定输入一列或多列的值的限定,在列中更新数据时,所要输入的剧情必须满意Check约束的规格,不然将不可能准确输入。

3、假诺对单个列定义 CHECK 约束,那么该列只同意特定的值。

4、借使对三个表定义 CHECK 约束,那么此约束会在一定的列中对值进行界定。

DEFAULT约束增加法则

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

2、假使“暗中同意值”字段中的项替换绑定的默许值(以不带圆括号的款型展现),则将唤起您解决对暗许值的绑定,并将其替换为新的默许值。

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

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

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

选择SSMS数据库管理工科具增多CHECK约束

1、连接数据库,选拔数据库,接纳数据表-》右键点击(可能直接点击约束,右键点击,接收丰硕约束,前边步骤同样)-》采用设计。

图片 1

2、选拔要增添约束的数码列-》右键点击-》选取CHECK约束。

图片 2

3、在CHECK约束弹出框中式点心击增多。

图片 3

4、在CHECK约束弹出框中-》输入CHECK约束表明式-》输入CHECK约束名-》输入CHECK约束描述-》其余能够挑选默许。

图片 4

5、点击关闭-》点击保存开关(也许ctrl+s)-》刷新表查看结果。

图片 5

运用SSMS数据库处理工科具加多DEFAULT约束

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

图片 6

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

图片 7

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

图片 8

采纳T-SQL脚本增加CHECK约束

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

当表结构存在时

增添CHECK约束时首先校验约束是还是不是已存在,假诺存在应该是先删除再增多,假若一纸空文则一向抬高。

语法:

-- 增加三个默许约束
use 数据库名;
go

if exists(select * from sysobjects where name=约束名)
alter table 表名 drop constraint 约束名;
go

alter table 表名 add constraint 约束名 check(约束准绳),constraint 约束名 check(约束准绳);
go

示例:

-- 增添多少个默许约束
use testss;
go

if exists(select * from sysobjects where name='check1')
alter table test1 drop constraint check1;
go

alter table test1 add constraint check1 check(height>=170 and height<=175);
go

 图片 9

图片 10

当表结构已存在时

第风姿洒脱决断表中是不是留存暗中同意约束,假设存在则先删除私下认可约束再增多,倘使荒诞不经则平素抬高。

语法:

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

当表结构不真实时

只要表结构不设有,能够平昔抬高约束,能够况且丰盛贰个也许多少个约束。

语法:

--假使表结构不设有的时候增添check约束
use 数据库名;
go
--假设已存在表则删除
if exists(select * from sysobjects where name=表名 and xtype='U')
drop table 表名;
go
--创建表
create table 表名
(
--字段注脚
列名 int identity(1,1) not null,
列名 nvarchar(50) null,
列名 nvarchar(50) null constraint 约束名 check(约束法则),
列名 nvarchar(50) null,
列名 int,
列名 int constraint 约束名 check(约束法规)
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

示例:

--假若表结构海市蜃楼时增多check约束
use testss;
go
--就算已存在表则删除
if exists(select * from sysobjects where name='test1' and xtype='U')
drop table test1;
go
--创建表
create table test1
(
--字段注解
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null constraint check1 check(sex='男' or sex='女'),
age nvarchar(50) null,
classid int,
height int constraint check2 check(height>=110 and height<=120)
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

 图片 13

图片 14

图片 15

创建表时丰硕私下认可约束

先是判定表是不是选在,假设存在则先删除表再增加,假若不设有则平昔抬高。

语法:

--创设新表时加多暗中认可约束
--数据库注解
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

图片 16

图片 17

CHECK约束优缺点

优点:

1、保障列数据规范和界定,能够约束数据完整性

2、有Check约束的列能够提供给查询优化器音信之所以进级质量

缺点:

1、插入恐怕涂改时数据不符合约束法规,不能够修改成功。

DEFAULT约束优缺点

优点:

1、使用私下认可值能够减掉代码量,新扩大多少时方可不用写新添暗中认可值列,实践新扩充操作时时私下认可填充。

2、较有利开展总括和剖判,以至方便程序逻辑操作。

缺点:

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

 

本文由美高梅游戏官网娱乐发布于数据库,转载请注明出处:慎选数据表-》右键点击(恐怕直接点击约束,4、

关键词: