Database 板


LINE

※ 引述《TeemingVoid (TeemingVoid)》之铭言: : ※ 引述《SonEat (善液)》之铭言: : : table : : ID element : : 1 Bi : : 1 Na : : 2 Bi : : 2 Na : : 2 O : : 3 Bi : : 3 C : : 因为mysql没有Intersection查询的功能可用 : : 因此我的问题 : : 1. 我想查出至少包含Bi与Na的ID 也就是查询结果为 1,2 : : 我原本用select * from table where element='Bi' and element='Na'结果会查出空集合 : : select * from table where element='Bi' or element='Na' 则会查出 1,2,3 : -- 依你提出的资料为例: : use test; : create table MoleculeElement : ( : MoleculeID int, : Element varchar(2) : ); : insert into MoleculeElement values : (1,'Bi'),(1,'Na'), : (2,'Bi'),(2,'Na'),(2,'O'), : (3,'Bi'),(3,'C'); : -- 利用子查询分别找出两个元素的资料,再以 inner join 取交集 : -- 查出至少包含 Bi 与 Na 的 ID,也就是查询结果为 1, 2 : select A.MoleculeID : from ( : select MoleculeID, Element from MoleculeElement where Element = 'Bi' : ) as A : join ( : select MoleculeID, Element from MoleculeElement where Element = 'Na' : ) as B : on (A.MoleculeID = B.MoleculeID); : : 2. 我想查出只有包含Bi与Na两种元素的ID 也就是查询结果为 1 : -- 继续找出元素数量正好是二的分子,再取一次交集 : select MoleculeID : from ( : select MoleculeID, Element from MoleculeElement where Element = 'Bi' : ) as A : join ( : select MoleculeID, Element from MoleculeElement where Element = 'Na' : ) as B : using (MoleculeID) : join ( : select MoleculeID from MoleculeElement : group by MoleculeID having count(*) = 2 : ) as C : using (MoleculeID) 小弟愚钝 再追加一个差集的问题 我把原表再多一栏 table:MoleculeElement MoleculeID Element Number 1 Bi 1 1 Na 3 2 Bi 1 2 Na 1 2 O 1 3 Bi 3 3 C 1 create table MoleculeElement ( MoleculeID int, Element varchar(2), Number int ); insert into MoleculeElement values (1,'Bi',1),(1,'Na',3), (2,'Bi',1),(2,'Na',1),(2,'O',1), (3,'Bi',1),(3,'C',3); 我想查询同时有Na与Bi的结果,也就是原问题1,再排除Na的Number=3的结果 也就是查询结果只得到 2 小弟试着用left join与not exists都失败,请问该如何修正? select MoleculeID from ( select MoleculeID, Element from MoleculeElement where Element = 'Bi' ) as A join ( select MoleculeID, Element from MoleculeElement where Element = 'Na' ) as B using (MoleculeID) left join (select MoleculeID, Element from MoleculeElement where Element = 'Na' and Number=3 ) as C using (MoleculeID); 失败,得到结果1,2 select MoleculeID from ( select MoleculeID, Element from MoleculeElement where Element = 'Bi' ) as A join ( select MoleculeID, Element from MoleculeElement where Element = 'Na' ) as B using (MoleculeID) where not exists (select MoleculeID, Element from MoleculeElement where Element = 'Na' and Number=3); 失败,得到Empty set --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 103.6.151.80







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP