欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

求一查询语句,一张表在另一个分类表中都有的数据如下

更新时间: 2014-01-05 02:12:36 责任编辑: Author_N1

 

求一查询语句,一张表在另一个分类表中都有的数据如下 在线等
CREATE TABLE T_TYPE
(
       T_TYPE_ID NUMBER,
       T_TYPE_NAME VARCHAR2(20)
);
INSERT INTO T_TYPE 
SELECT 1, '苹果' FROM DUAL UNION ALL 
SELECT 2, '香蕉' FROM DUAL;

CREATE TABLE T_INFO
(
       T_PERSON_ID NUMBER,
       T_PERSON_NAME VARCHAR(20),
       T_TYPE_ID DECIMAL
);
INSERT INTO T_INFO 
SELECT 1, '张三', 1 FROM DUAL UNION ALL 
SELECT 1, '张三', 2 FROM DUAL UNION ALL 
SELECT 2, '李四', 1 FROM DUAL
/*
求T_INFO表中T_PERSON_ID的T_TYPE_ID在表T_TYPE中都有的人
结果是张三
*/


--参考方法--
SELECT A.T_PERSON_NAME FROM T_INFO A,T_TYPE B,T_TYPE C
WHERE A.T_PERSON_ID=B.T_TYPE_ID AND A.T_TYPE_ID=C.T_TYPE_ID
--参考方法--

select T_PERSON_NAME
from t_info 
group by T_PERSON_NAME
having count(*) = (select count(*) from t_type)

--参考方法--
引用:

SELECT DISTINCT T_Person_Name
FROM T_Info A
WHERE NOT EXISTS (
  (SELECT T_Type_Id FROM T_Info WHERE T_Person_Name=A.T_Person_Name
  MINUS
  SELECT T_Type_Id FROM T_Type
  )
UNION ALL
  ( SELECT T_Type_Id FROM T_Type
  MINUS
  SELECT T_Type_Id FROM T_Info WHERE T_Person_Name=A.T_Person_Name
  ) ) ;

这里我做一点限制,如果T_Info中出现了T_Type没有的ID,则不符合要求
如果不求这个限制,可以把union all前面的select语句去掉
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:12:36
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/6986/
本文WWW.DOC100.NET DOC100.NET版权所有。