首页 数据库 mysql教程 约束与数据库对象规则、默认值的探究

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

Jun 07, 2016 pm 03:35 PM
对象 探究 数据库 约束 规则 默认 默认值

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

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

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

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

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

    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
<p><br>
    创建了一个表该表中有三个字段,name、department、salary,并在salary字段设置了约束条件。该表如下图:</p>
<p></p>
<p><span>     <img  src="/static/imghw/default1.png" data-src="/inc/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" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></span></p>
<p><span>    <span>
在表中填数据时后两个不符合条件是不正确的。</span></span></p>
<p><span>    在约束中还分为两种:<span>字段级约束和表级约束</span>。字段级约束是只约束其中的一列,表级约束是约束多列,它们两个的区别并不大,我们在理解时可以将表级理解为字段级,即:被约束的多列可以看做捆绑成一列,被捆绑后的字段中的两个记录是不能重复的,如:</span></p>
<p><span><img  src="/static/imghw/default1.png" data-src="/inc/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" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></span></p>
<p><span><br clear="all">
</span></p>
<p><span>    2、规则,规则顾名思义是规矩制度的意思,在进行表操作时它的作用和check约束条件是类似的,但是一个表中只有一个规则,可有多个check约束,如:</span></p>
<p><span>    </span></p>
<pre class="brush:php;toolbar:false">     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
<p><br>
<span>     表说明如下:</span></p>
<p><img  src="/static/imghw/default1.png" data-src="/inc/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" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></p>
<p><span>    3、默认值,用法同规则,它的作用类似于Default约束,是说在表中插入数据时,如果没有指定值,默认值自动指定数据值。</span></p>
<p><span>接下来我们在语法上分析三者,看图:</span></p>
<p><img  src="/static/imghw/default1.png" data-src="/inc/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" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></p>
<p></p>
<p><span>       1、约束,创建方法大致有三种:</span></p>
<p><span>               </span></p>
<pre class="brush:php;toolbar:false"> 	——方法一:在创建表时用字句的方式创建约束

	CREATE TABLE 表名(

            列名数据类型,

            ……

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

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

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

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

</span>	);

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

	CREATE TABLE 表名(

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

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

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

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

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

	)

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

<span>	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 (检查条件);
</span>
登录后复制

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

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

             

   ——创建

 <span>   Create rule 规则名 as 条件表达式
</span>
    ——绑定

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

</span>    ——解除绑定

  <span>  sp_unbindrule  ‘表名.字段名’ | ‘数据类型’
</span>
    ——删除规则

    <span>DROP RULE {rule_name} [,...n]
</span>
登录后复制

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

     

      三者间的关系很清楚了吧。约束与数据库对象规则、默认值的探究

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

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

 

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

Hibernate 如何实现多态映射? Hibernate 如何实现多态映射? Apr 17, 2024 pm 12:09 PM

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

如何将 MySQL 查询结果数组转换为对象? 如何将 MySQL 查询结果数组转换为对象? Apr 29, 2024 pm 01:09 PM

将MySQL查询结果数组转换为对象的方法如下:创建一个空对象数组。循环结果数组并为每一行创建一个新的对象。使用foreach循环将每一行的键值对赋给新对象的相应属性。将新对象添加到对象数组中。关闭数据库连接。

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

指针比较的规则和例外? 指针比较的规则和例外? Jun 04, 2024 pm 06:01 PM

在C/C++中,指针比较规则如下:指向同一对象的指针相等。指向不同对象的指针不相等。例外:指向空地址的指针相等。

如何在PHP中处理数据库连接错误 如何在PHP中处理数据库连接错误 Jun 05, 2024 pm 02:16 PM

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

C++ 函数返回对象时有什么需要注意的? C++ 函数返回对象时有什么需要注意的? Apr 19, 2024 pm 12:15 PM

在C++中,函数返回对象需要注意三点:对象的生命周期由调用者负责管理,以防止内存泄漏。避免悬垂指针,通过动态分配内存或返回对象本身来确保对象在函数返回后仍然有效。编译器可能会优化返回对象的副本生成,以提高性能,但如果对象是值语义传递的,则无需副本生成。

数组和对象在 PHP 中的区别是什么? 数组和对象在 PHP 中的区别是什么? Apr 29, 2024 pm 02:39 PM

PHP中,数组是有序序列,以索引访问元素;对象是具有属性和方法的实体,通过new关键字创建。数组访问通过索引,对象访问通过属性/方法。数组值传递,对象引用传递。

See all articles