`
sjk2013
  • 浏览: 2190137 次
文章分类
社区版块
存档分类
最新评论

约束与数据库对象规则、默认值的探究

 
阅读更多

约束、规则、默认值这三者在数据表中规定了数据进行操作时的限制条件。他们三者有关系也有区别,用了两天的时间研究了他们三者,总结如下。

首先让我们从关系角度来分析:

●浅谈约束、规则、默认值

1、约束,约束顾名思义是限制条件的意思,其实它的作用也是如此,它是对所要进行增删改查操作的数据进行一次检查,检查这些数据是否符合我们所要约束的条件。举个例子:我们都经历过高考,考试规定考生不许带与考试无关的物品这就是一种约束。报名考试的考生可能因为某些意外没有进入考场考试,但大部分考生还是进行了考试。那么在考场内就产生了两种情况空位和非空位,这就是我们约束条件的两种情况。我们继续分析,在考生进入考场的情况中,考生在答卷之前是必须要在试卷和答题卡上填写自己的信息的,这些信息都是必须要填的因为它们唯一确定了一个考生,这里考生必须填写考生信息也就是我们所说的主键约束(主关键字约束)。接下来我们用两个表来说明下外键约束:

那么如果我们在字段后面用Not Null规定了呢?也就是说在我们的考生信息表中的性别字段,该列是不允许为空的于是就用Not Null标识,但是如果我们不填的话呢,我们的系统就会用Default默认值约束来帮助我们天上一个值。接下来我们来看Check约束,该约束是要用条件表达式来限定所要填的数据的,如下:

         Create table 工资 (

                  name  char(10) primary key,

                  department  char(20) Not Null,

                  salary int not null check(salary>1000 and salary<4000)

         )


创建了一个表该表中有三个字段,name、department、salary,并在salary字段设置了约束条件。该表如下图:

在表中填数据时后两个不符合条件是不正确的。

在约束中还分为两种:字段级约束和表级约束。字段级约束是只约束其中的一列,表级约束是约束多列,它们两个的区别并不大,我们在理解时可以将表级理解为字段级,即:被约束的多列可以看做捆绑成一列,被捆绑后的字段中的两个记录是不能重复的,如:


2、规则,规则顾名思义是规矩制度的意思,在进行表操作时它的作用和check约束条件是类似的,但是一个表中只有一个规则,可有多个check约束,如:

     Create table 薪水(

            name  char(10) primary key,

            position  char(20) Not Null,

            salary int not null

         )

     Create rule ru_salary

     As @salary>1000 and @salary<4000

     Go

     Exec sp_bindrule ‘ru_salary’,  ’薪水.salary’

       Go


表说明如下:

3、默认值,用法同规则,它的作用类似于Default约束,是说在表中插入数据时,如果没有指定值,默认值自动指定数据值。

接下来我们在语法上分析三者,看图:

1、约束,创建方法大致有三种:

 	——方法一:在创建表时用字句的方式创建约束

	CREATE TABLE 表名(

            列名数据类型,

            ……

            CONSTRAINT 约束名 PRIMARY KEY (列名),                       ——主键约束

            CONSTRAINT 约束名 UNIQUE (列名),                            ——唯一约束

            CONSTRAINT 约束名 FOREIGN KEY (列名) REFERENCES 表名 (列名),  ——外键约束

            CONSTRAINT 约束名 CHECK (检查条件)                           ——Check约束

	);

        ——方法二:在创建表时直接定义约束

	CREATE TABLE 表名(

            列名数据类型 NOT NULL,                                        ——非空约束

            列名数据类型 NOT NULL PRIMARY KEY,                            ——主键约束

            列名数据类型 NOT NULL UNIQUE,                                 ——唯一约束

            列名数据类型 [NOT NULL] REFERENCES 表名(列名),                ——外键约束

            列名数据类型 [NOT NULL] CHECK (检查条件)                         ——Check约束

	)

       ——方法三:在创建表后,通过更改表来定义

	ALTER TABLE 表名 ALTER COLUMN 列名 SET NOT NULL;

	ALTER TABLE 表名 ADD PRIMARY KEY (列名1,列名2…);

	ALTER TABLE 表名 ADD UNIQUE (列名1,列名2,……);

	ALTER TABLE 表名 ADD FOREIGN KEY(列名) REFERENCES 表名2 (列名2);

	ALTER TABLE 表名 ADD CHECK (检查条件);

删除约束的语法为:ALTER TABLE 表名 DROP CONSTRAINT 约束名

2、规则。规则的应用操作,首先要创建但只创建是不能应用的要用sp_bindrule将规则绑定到字段或自定义的数据类型上才能起作用。

   ——创建

    Create rule 规则名 as 条件表达式

    ——绑定

    Exec sp_bindrule ‘规则名’  , ‘表名.字段名’ | ‘数据类型’

    ——解除绑定

    sp_unbindrule  ‘表名.字段名’ | ‘数据类型’

    ——删除规则

    DROP RULE {rule_name} [,...n]

3、默认值的语法和规则是类似的,只需将规则中的rule改成关键字default即可。

三者间的关系很清楚了吧。微笑

上面两个导图看不清怎么办,不用着急来这儿下载吧:http://163.fm/8S2n28H 提取码:0lUKbp0z

http://163.fm/GktKqwV 提取码:Dc6THqqH

分享到:
评论

相关推荐

    数据库默认值约束默认值对象检查约束规则完整性实现PPT学习教案.pptx

    数据库默认值约束默认值对象检查约束规则完整性实现PPT学习教案.pptx

    Asp添加数据库字段与修改数据库字段默认值的方法共享.pdf

    Asp添加数据库字段与修改数据库字段默认值的方法共享.pdf

    SQL Server 面面观?数据库对象

    SQL Server 2008包含许多对象,主要的数据库对象有:数据库、事务日志、表、模式、文件组、图表、视图、存储过程、用户自定义函数、用户和角色、规则、默认值、用户自定义数据类型、全文目录。  一、数据库对象 ...

    ES6知识点整理之函数对象参数默认值及其解构应用示例

    函数对象参数的默认值与解构的形式 此处使用箭头函数来处理 : (({x,y})=&gt;{ console.log(x, y); // // undefined undefined })({}); (({x=1,y=2})=&gt;{ console.log(x,y); // 1 2 })({}); (({x=3, y=4}={})=&gt;{ ...

    删除MSSQL默认约束

    MSSQL 约束 默认值 删除整个库里所有默认值。

    数据库动态加载匿名对象

    4 常规类型与对象类型混合的匿名类型 5 匿名类型之间可嵌套 6 公有属性 可写 公有字段) 特性: 1 数据库字段与类属性或类字段按名称映射 2 数据库字段与类属性或类字段不区分大小写映射 3 始终按先区分...

    SQL学习教程-约束,索引,视图,函数

    介绍就不用说了,跟上次那个是一起的。 这是约束,索引,函数,视图部分

    auto-value-firebase, 创建Firebase数据库对象的AutoValue扩展.zip

    value-firebase, 创建Firebase数据库对象的AutoValue扩展 AutoValue: Firebase扩展对于与 Firebase实时数据库兼容的值类,必须:包含 public"获取"-prefixed访问器或者 public 字段,以及包含一个空的或者"默认值...

    数据库系统概论(王珊第五版)数据库实验9.doc

    掌握默认值约束和默认值对象的应用; 3. 掌握用触发器实现参照完整性的方法。 二、实验学时 2学时 三、实验要求 1. 了解约束、默认值; 2. 了解触发器的定义方法; 3. 掌握触发器的编写和运行方法 4. 完成实验报告...

    PostgreSQL 10 基础课程第二章 数据库管理设置及修改默认值

    PostgreSQL 10 基础课程第二章 数据库管理设置及修改默认值

    数据库系统之实体完整性约束.pdf

    数据库系统之实体完整性约束 数据库系统之实体完整性约束 数据库完整性 数据库完整性 今天做了⼀道数据库的上机题,其中的⼀些知识觉得挺有⽤的,因此打算整理出来⼀篇博客来与⼤家分享⼀下。这⾥的语句针对的都是...

    android数据库Realm版本更新

    Realm数据库操作,增删改查操作,版本更新(数据迁移)。

    数据库上机实验课课件

    SQL Server 关系数据库简介 管理SQL Server 服务器;建立与管理数据库;建立与管理表、视图、存储过程、触发程序、角色、规则、默认值等数据库对象,以及用户定义的数据类型;备份数据库和事务日志、恢复数据库;

    北邮数据库实验5数据库完整性与安全性

    1. 通过对完整性规则的定义实现,熟悉...本实验将针对这11张表,采用alter table语句,添加主键、候选键、外键、check约束、缺省/默认值约束,并观察当用户对数据库进行增、删、改操作时,DBMS如何维护完整性约束。

    1数据库大作业.doc

    6 2.2设置约束 6 2.2.1设置主键约束 6 2.2.2设置外键约束 6 2.2.3设置check约束 6 2.2.4设置默认值 6 2.2.5设置规则 6 2.3建立索引 6 2.4创建视图 6 2.5查询 7 1数据库设计 数据库在一个信息管理系统中占有非常重要...

    MySQL约束(三).pdf

    内容概要 这份PDF文档深入探讨了MySQL数据库中的各种约束类型及其应用,是约束系列教程的第三部分。主要内容包括: PRIMARY KEY约束:定义主键及其在数据...数据分析师:在进行数据分析前,需要了解数据的约束规则。

    ECShop 2.7.2版本数据库表

    ECShop 2.7.2版本,数据库表,数据库属性、默认值、注释。一眼明了,再也不用担心不知道数据结构和字段对应状况了。轻松搞定数据结构,表关联问题

    数据库原理及应用实验五(数据完整性和安全性)

    4. 掌握默认值的创建、实施与删除方法。 5. 掌握规则的创建、实施与删除方法。 6. 掌握级联删除、级联修改方法。 7. 理解索引的概念与类型。 8. 掌握使用SQL Server Management Studio创建与维护索引的方法。 9. ...

Global site tag (gtag.js) - Google Analytics