navacate关联外键

一基本建表新建两个表:table1 table2

 Table 1iduidname),uid为设置的外键,外键不用设置自动自增以及无符号处不要画√。id为主键,设置为自增。


Table2 uidname,uid设置为自增。


注意(table1的关联uidtable2uid要字段类型一致,且长度小数等都一致(table1中的关联字段uid不用设置自增,且不能设置无符号处打对号,table2中的也是。))

二设置关联。

 

右键table1-》设计表-》索引。


建表首先建立索引,索引名自己起,栏位是要关联的表中有的要设置为外键的字段的名字。

所以类型 以及所以方式,参考上图。

 

然后点击所以旁边的外键


“名”可以与索引名不一致,不会报错,栏位名同索引中栏位,参考数据库为你要设置外键的字段所在的数据库,参考表即外键所在的表,参考栏位即参考表中外键在参考表中的名字。

 

 

三:最重要一点。

关联外键,一般是在刚开始建表时候,就建立好,因为刚开始两个表都为空。

如果两个不同的表,两个表都有记录,则可能两个表中,你想设置为外键的字段与参考表中的参考字段,两者字段值(已有记录中的),对应不上,则导致失败(错误代码1452),若是父表有记录,外键所在表没记录或者外键所在表的记录外键id都在父表中能找到,则不会出现问题。(详细原因,在于外键删除时以及更新时类型设置)



 

外键理解:

1)候选键: 关系中的一个属性组,其值能唯一标识一个元组,若从该属性组中去掉任何一个属性,它就不具有这一性质了,这样的属性组称作候选码。
2)主键:当有多个候选码时,可以选定一个作为主码,选定的候选码称主键
3)外键: 关系R中的一个属性组,它不是R的候选码,但它与另一个关系S的候选码相对应,则称这个属性组为R的外码或外键。
举个例子:
有两个关系:
student(s#,sname,d#),即学生这个关系有三个属性:学号,姓名,所在系别
dep(d#,dname),即院系有两个属性:系号、系名
s#、d#是主键,也是各自所在关系的唯一候选键,d#是student的外键。

 

 

oracle数据库中,当对父表(上面例子中的dep表)进行更新的时候,如果在子表(上面例子中的student表)中的外键没有使用索引,则在更新的过程中整个子表将被锁定,而往往实际上并不需要锁定整个子表,而仅仅需要锁定子表中的几条记录。这样就会大大影响数据库访问的并发性,甚至有可能造成死锁的情况。

 

1当使用ON DELETE CASCADE删除父表中的记录时,如果在子表中的外键没有使用索引则当执行该操作时会对子表进行全表的扫描,而事实上这个全表的扫描是不需要的。更坏的情况是,如果删除多个父表中的记录,每删除一条记录则会进行一次全表扫描,可想而知,对于性能的影响是多么的大!

2对于父表和子表的连接查询,情况也是类似的。当进行这种连接查询时,如果不对外键使用索引则会发现查询的速度大大降低。

这下你一定明白了为什么需要在外键上使用索引的重要意义了,不过你还是坚持不想使用索引的话,也可以,不过必须保证下面三种情况同时满足:

1. 不从父表中删除记录

2. 不更新父表中的主键的值

3. 一般不进行父表和子表的链接查询。

4. 如果你觉得你可以满足上面的全部三个条件,那么你可以不必为外键添加索引。不过一般来讲,上面的三种情况很难满足,而如果你没有使用索引的话,那么你将为此付出很大的代价的!

 

 

什么是索引?

一个索引是存储的表中一个特定列的值数据结构(最常见的是B-Tree)。索引是在表的列上创建。所以,要记住的关键点是索引包含一个表中列的值,并且这些值存储在一个数据结构中。请记住记住这一点:索引是一种数据结构

什么样的数据结构可以作为索引?

B-Tree 是最常用的用于索引的数据结构。因为它们是时间复杂度低, 查找、删除、插入操作都可以可以在对数时间内完成。另外一个重要原因存储在B-Tree中的数据是有序的。数据库管理系统(RDBMS)通常决定索引应该用哪些数据结构。但是,在某些情况下,你在创建索引时可以指定索引要使用的数据结构。

哈希表索引是怎么工作的?

哈希表是另外一种你可能看到用作索引的数据结构-这些索引通常被称为哈希索引。使用哈希索引的原因是,在寻找值时哈希表效率极高。所以,如果使用哈希索引,对于比较字符串是否相等的查询能够极快的检索出的值。例如之前我们讨论过的这个查询(SELECT * FROM Employee WHERE Employee_Name = ‘Jesus’) 就可以受益于创建在Employee_Name 列上的哈希索引。哈系索引的工作方式是将列的值作为索引的键值(key),和键值相对应实际的值(value)是指向该表中相应行的指针。因为哈希表基本上可以看作是关联数组,一个典型的数据项就像“Jesus  => 0x28939″,而0x28939是对内存中表中包含Jesus这一行的引用。在哈系索引的中查询一个像“Jesus”这样的值,并得到对应行的在内存中的引用,明显要比扫描全表获得值为“Jesus”的行的方式快很多。

 

 

 

删除索引创建索引几个字段的含义:

当取值为No Action或者Restrict时,则当在父表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除。

 

当取值为Cascade时,则当在父表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有则也删除外键在子表(即包含外键的表)中的记录。

当取值为Set Null时,则当在父表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(不过这就要求该外键允许取null)。

 

 

Update

当取值为No Action或者Restrict时,则当在父表(即外键的来源表)中更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许更新。

当取值为Cascade时,则当在父表(即外键的来源表)中更新对应记录时,首先检查该记录是否有对应外键,如果有则也更新外键在子表(即包含外键的表)中的记录。

当取值为Set Null时,则当在父表(即外键的来源表)中更新对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(不过这就要求该外键允许取null)。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值