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

约束、规则、默认这三者在数据表中规定了数据进行操作时的限制条件。他们三者有关系也有区别,用了两天的时间研究了他们三者,总结如下。 首先让我们从关系角度来分析: ●浅谈约束、规则、默认 1、约束,约束顾名思义是限制条件的意思,其实它的作用也是如

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

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

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397742_7768.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

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

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

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397833_4654.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

那么如果我们在字段后面用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字段设置了约束条件。该表如下图:

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397842_8207.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

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

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

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397860_9111.png&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

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

表说明如下:

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397842_8207.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

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

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

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397923_5880.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

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即可。

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

test.jsp?url=http%3A%2F%2Fstatic.blog.csdn.net%2Fxheditor%2Fxheditor_emot%2Fdefault%2Fsmile.gif&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150

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

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

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值