下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、mysql中唯一索引和唯一约束炎谈唯一约束和唯一索引约束全称完整性约束,它是关系数据库中的对象,用来存放插入到一个表中一列数据的规则,用来确保数据的准确性和一致性。索引数据库中用的最频繁的操作是数据查询,索引就是为了加速表中数据行的检索而创建的一种分散的数据结构。可以把索引类比成书的目录,有目录的肯定比没有目录的书,更方便查找。唯一约束保证在一个字段或者一组字段里的数据都与表中其它行的对应数据不同。和主键约束不同,唯一约束允许为NULL,只是只能有一行。唯一索引不允许具有索引值相同的行,从而禁止重复的索引或键值。唯一约束和唯一索引都是为了保证表中被限制的字段不允许有重复的值,看起来功能是一样的
2、,那为什么要设计这样两种一样的功能呢?首先创建两个字段值一样的表t1,t2,并为t1表中的coll列设置唯一约束。CREATETABLEt1(col1INT(11),col2VARCHAR(20),CONSTRAINTt1_uqUNIQUE(col1);CREATETABLEt2(col1INT(11),col2VARCHAR(20);然后为表t2表中的col1列设置唯一索引CREATEUNIQUEINDEXt2_idxONt2(col1);创建表t3,并将t1表中的col1列设置为t3表中col2列的外键CREATETABLEt3(col1INT(11),col2INT(11),col3VA
3、RCHAR(20),CONSTRAINTt3_fkFOREIGNKEY(col2)REFERENCESt1(col1);到此为止,基本上就能得出,唯一约束和唯一索引在MySQL数据库里区别了概念上不同,约束是为了保证数据的完整性,索引是为了辅助查询;创建唯一约束时,会自动的创建唯一索引;在理论上,不一样,在实际使用时,基本没有区别。关于第二条,MySQL中唯一约束是通过唯一索引实现的,为了保证没有重复值,在插入新记录时会再检索一遍,怎样检索快,当然是建索引了,所以,在创建唯一约束的时候就创建了唯一索引。唯一性索引如果确定某个数据列只包含彼此各不相同的值,在为这个数据列创建索引的时候,就应该用关
4、键字UNIQUE把它定义为一个唯一索引,Mysql会在有新纪录插入数据表时,自动检查新纪录的这个字段的值是否已经在某个记录的这个字段里出现过了。如果是,mysql将拒绝插入那条新纪录。也就是说,唯一索引可以保证数据记录的唯一性。事实上,在许多场合,人们创建唯一索引的目的往往不是为了提高访问速度,而只是为了避免数据出现重复索引的优点可以通过建立唯一索引或者主键索引,保证数据库表中每一行数据的唯一性建立索引可以大大提高检索的数据,以及减少表的检索行数在表连接的连接条件,可以加速表与表直接的相连在分组和排序字句进行数据检索,可以减少查询时间中分组和排序时所消耗的时间(数据库的记录会重新排序)建立索引
5、,在查询中使用索引,可以提高性能。CREATETABLEparent(idINTNOTNULL,PRIMARYKEY(id)TYPE=INNODB;CREATETABLEchild(idINT,parent_idINT,INDEXpar_ind(parent_id),FOREIGNKEY(parent_id)REFERENCESparent(id)ONDELETECASCADE)TYPE=INNODB;如下是一个更复杂的例子,其中一个product_order表对其它两个表有外键。一个外键引用一个product表中的双列索引。另一个引用在customer表中的单行索引:CREATETABLEp
6、roduct(2categoryINTNOTNULL,4idINTNOTNULL,6priceDECIMAL,8PRIMARYKEY(category,id)10)TYPE=INNODB;1213CREATETABLEcustomer(idINTNOTNULL,PRIMARYKEY(id)TYPE=INNODB;CREATETABLEproduct_order(noINTNOTNULLAUTO_INCREMENT,product_categoryINTNOTNULL,product_idINTNOTNULL,customer_idINTNOTNULL,PRIMARYKEY(no),INDEX(product_category,product_id),FOREIGNKEY(product_category,product_id)REFERENCESproduct(category,id)ONUPDATECASCADEONDELETERESTRICT,INDEX(customer_id),FOREIGNKEY(cust
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026云南怒江州福贡县鹿马登乡人民政府招聘文职森管员1人备考题库及完整答案详解(全优)
- 2026广东佛山市南海区大沥镇太平成远小学招聘备考题库附答案详解(研优卷)
- 2026江苏南通市儿童福利中心招聘政府购买服务岗位人员1人备考题库完整版附答案详解
- 2026上半年四川事业单位统考遂宁市考试招聘174人备考题库【预热题】附答案详解
- 记账实操-电网代征各项基金的会计账务处理分录
- 世界著名五禽戏传承人介绍【课件文档】
- 2026四川阿坝州锦宸口腔招聘8人备考题库含答案详解(满分必刷)
- 2026广东惠州博罗县园洲镇九潭卫生院招聘编外工作人员1人备考题库及参考答案详解(黄金题型)
- 2026安徽池州市直学校招聘教师14人备考题库【能力提升】附答案详解
- 2026春季河北邯郸市教育局市直学校选聘博硕人才300人备考题库含答案详解(能力提升)
- 小儿药液外渗的预防及护理
- DB32-T 4787-2024 城镇户外广告和店招标牌设施设置技术标准
- AQ/T 1119-2023 煤矿井下人员定位系统通 用技术条件(正式版)
- 2024年厦门航空有限公司招聘笔试参考题库含答案解析
- 林城镇卫生院安全生产制度
- 南京航空航天大学“天目启航”学生自由探索项目申请书
- EIM Starter Unit 6 This is delicious单元知识听写单
- 陕西铜川声威特种水泥有限公司2500t-d新型干法特种水泥熟料技改生产线项目环评报告
- GB/T 4062-2013三氧化二锑
- GB/T 26746-2011矿物棉喷涂绝热层
- GB 30616-2020食品安全国家标准食品用香精
评论
0/150
提交评论