您的位置:威尼斯官方网站 > 威尼斯官方网站登录 > 3、要是对单个列定义 CHECK

3、要是对单个列定义 CHECK

发布时间:2019-08-05 17:09编辑:威尼斯官方网站登录浏览(148)

    CHECK约束增加法则

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

    2、Check约束通过逻辑表明式来推断数据的实用,用来界定输入一列或多列的值的限量,在列中立异数据时,所要输入的从头到尾的经过必须满意Check约束的尺度,不然将不可能正确输入。

    3、即使对单个列定义 CHECK 约束,那么该列只允许特定的值。

    4、假如对二个表定义 CHECK 约束,那么此约束会在一定的列中对值举行界定。

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

    1、连接数据库,选取数据库,选拔数据表-》右键点击(或然直接点击约束,右键点击,选用丰盛约束,前边步骤同样)-》选拔设计。

    威尼斯官方网站 1

    2、选用要丰硕约束的数码列-》右键点击-》选拔CHECK约束。

    威尼斯官方网站 2

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

    威尼斯官方网站 3

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

    威尼斯官方网站 4

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

    威尼斯官方网站 5

    运用T-SQL脚本增加CHECK约束

    当表结构存在时

    增添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

     威尼斯官方网站 6

    威尼斯官方网站 7

    当表结构不设一时

    如若表结构官样文章,能够平素抬高约束,能够並且加上三个照旧四个约束。

    语法:

    --倘诺表结构子虚乌有时增多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

     威尼斯官方网站 8

    威尼斯官方网站 9

    威尼斯官方网站 10

    CHECK约束优劣点

    优点:

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

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

    缺点:

    1、插入或然修改时数据不符合约束法则,无法修改成功。

    本文由威尼斯官方网站发布于威尼斯官方网站登录,转载请注明出处:3、要是对单个列定义 CHECK

    关键词: