時(shí)間:2015-06-28 00:00:00 來(lái)源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評(píng)論(0)
假設(shè)有兩個(gè)關(guān)系,R(a,b,c)和T(b,c)
使用投影、笛卡爾積和集合的差,表示R÷T
R÷T = πa(R) - πa[ πa(R) × T – R ]
SQL:
select a from R
minus(
select a from(
select * from (select a from R), T
minus
select * from R
)
)
使用NOT EXISTS的實(shí)現(xiàn)
理解:為了幫助理解,假設(shè)有關(guān)系S(a,d,e),其中a為主鍵,對(duì)于關(guān)系T,(b,c)即為主鍵,那么R就是連接S,T的中間表。
1. 找出T中的一些元組,這些元組的中的(b,c)對(duì)于R中的不同的a并沒(méi)有全部包含在R的元組中;
2. 將上個(gè)步驟中的R的那些元組從R中排除掉。
SQL:
select distinct a from R r1 where not exists(? -- 相當(dāng)于關(guān)系S
select * from T where not exists(
select * from R r2 where r1.a = r2.a and? r2.b = t.b and r2.c = t.c
)
)
關(guān)鍵詞標(biāo)簽:關(guān)系數(shù)據(jù)庫(kù)
相關(guān)閱讀
熱門文章 Oracle中使用alter table來(lái)增加,刪除,修改列的語(yǔ)法 oracle中使用SQL語(yǔ)句修改字段類型-oracle修改SQL語(yǔ)句案例 誤刪Oracle數(shù)據(jù)庫(kù)實(shí)例的控制文件 為UNIX服務(wù)器設(shè)置Oracle全文檢索
人氣排行 oracle中使用SQL語(yǔ)句修改字段類型-oracle修改SQL語(yǔ)句案例 Oracle中使用alter table來(lái)增加,刪除,修改列的語(yǔ)法 ORACLE SQL 判斷字符串是否為數(shù)字的語(yǔ)句 ORACLE和SQL語(yǔ)法區(qū)別歸納(1) oracle grant 授權(quán)語(yǔ)句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法