问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

关系型数据库中的字段默认值、不可为空、唯一索引约束的好处和坏处是什么?

发布网友 发布时间:2022-04-11 22:18

我来回答

2个回答

懂视网 时间:2022-04-12 02:39

约束、规则、默认这三者在数据表中规定了数据进行操作时的限制条件。他们三者有关系也有区别,用了两天的时间研究了他们三者,总结如下。 首先让我们从关系角度来分析: ●浅谈约束、规则、默认 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<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

热心网友 时间:2022-04-11 23:47

好处:
字段默认:针对每个字段都有自己的默认值,较有利于进行统计和分析,以及方便程序逻辑操作;
不可为空:若是该字段创建为索引情况下,且允许为NULL,则存储多个值,若是不允许为空,可能用某一个值替代,则索引值更少,以及部分数据库产品不支持字段为NULL情况下创建索引(特别是早期的数据库产品)
唯一性约束:那是指有数据唯一性要求的情况下,可以借助数据库的方式判断是否存在重复值,而避免程序去判断,减少事务的处理等

坏处:
默认值和不可为空的影响基本可以忽略了,唯一约束的影响在于插入的时候它要对记录做个检查,略微有点开销。不该加唯一约束的地方加了的话,在插数据的时候可能还会报个错
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
南安椎间盘突出症的症状,悬壶邱腰神在陕西哪里 安康腰椎间盘突出一条腿麻保守治疗的方法,悬壶邱大夫的详细位置_百度知 ... 宣传片拍摄有哪些长处? 继承房产过户费用要多少? 继承5万房产过户需要多少费用多少钱 继承的房产过户需要多少费用 继承5万房产过户需要多少费用 灵芝茶减肥效果怎么样 南京滴滴和t3哪个收入多 属虎女人的和属鸡男人的配吗 求解:才接触数据库,纯新手,求教:检查约束和规则的区别,咋感觉都差不多??? 主键约束,外键约束,空值约束,默认值约束,唯一约束,检查约束的各个作用是什么? 在表中定义的默认值和check约束,与规则对象,默认值对象有何区别 约束和数据库对象的区别在哪里 (Bo-Blog)波-博客数据库系统提示:无法连接服务器 数据库登陆不上 是不是数据库本身的问题 VS连接数据库时为什么为说无法打开登陆所求的数据库,登录失败 数据库登陆的时候登陆不上出现这样的问题是什么情况? 我把我修改的默认数据库删了,登录不了SQL server了,我的是SQL server 2008R2,网上的方法不行!急救啊 sql server 连不上 错误提示:未能建立与PC-201001281436的连接。原因:无法打开用户默认数据库。登录失败 无法打开用户默认数据库。登陆失败。 用户SA登陆失败(SQL 错误4064) 怎么解决啊 asp.net无法打开用户默认数据库。登录失败。 labview选项卡控件增加或删除页面的属性节点怎么找到? 图中labview布尔和两个框的控件怎么设置的 我要如何在LabVIEW中改變人機介面上元件的Tab鍵切換順序? labview2015中簇控件怎么改成隐形 怎样用LabVIEW对控件进行禁用/可见控制? LabVIEW如何修改控件默认样式 labview中怎样使显示控件清零 labview8.5中怎样编写隐藏和显示控件 SQL 2005 ‘CHECK约束’ 和 ‘规则’ 区别 安装windows2003系统,同时运行nosql数据库,最少需要多大的内存 c++ 有哪些调试的技巧? C#如何调试代码调试技巧篇 舞台专业音响调试技巧,有谁知道的?在线等 均衡器最好的调试方法 超声波探伤仪调试技巧 调试技巧:如何以数组的方式查看一个指针 光脚丫学LINQ(024):如何通过修改DBML文件生成自定义代码 c#,linq中如何只显示数据库表的某一列或者某几列。。 如何创建自己的Linq provider C# linq Field 在数据库查出一列数据转换成int数组时报错? 如何可将数据库数据表列输出为表 java把oracle数据库里的表格(所有)显示到jsp页面上,对于动态的列名,如何生成get,set方法,求帮忙 假如我要将数据库中的一列数改为另一列数的前几个字,用语句怎么表示 C#如何通过后台设置点击按钮将数据库中指定行中的某一列字段改为1 用c#读取oracle数据库生成的零时列 数据库join到底是怎么个逻辑 数据库的JOIN,内部实现原理是怎么样的 数据库管理里的关系运算符——如(Restrict、Project、join)等等,他们的作用最好举例说明下, 谢谢!