原题来自:
http://sqlyuju.com/sql-server-oracle-nanti1.html
数据显示如下:
建表语句:
------问题----
数据显示如下:
建表语句:
点击(此处)折叠或打开
- create table test(
- name varchar(20),
- val varchar(20)
- );
- insert into test(name,val) values (\'小红\',\'c\');
- insert into test(name,val) values (\'小红\',\'d\');
- insert into test(name,val) values (\'小红\',\'e\');
- insert into test(name,val) values (\'小李\',\'c\');
- insert into test(name,val) values (\'小李\',\'e\');
- insert into test(name,val) values (\'小白\',\'c\');
- insert into test(name,val) values (\'小白\',\'d\');
- insert into test(name,val) values (\'小黑\',\'d\');
- commit;
--1、查询 val 为 c d e 的 只能找到 小红
--2、查询 val 为 c e 的 只能找到 小红 小李(如果只显示小李,又怎么写)
注意:上面其实是一个sql 传入不同的参数 如 'c','d','e' 或是 'c','e'
要求:sql server 语法 或是 Oracle 语法。
Oracle 实现:点击(此处)折叠或打开
- select *
- from (select name,
- count(distinct val) over() as c,
- count(distinct val) over(partition by name) as v
- from test_01
- where val in (\'c\', \'d\', \'e\'))
- where c = v;
-
- ----只显示小李
-
- SELECT NAME, v, COUNT(DISTINCT val) over(PARTITION BY NAME) AS v2
- FROM (SELECT NAME, val, COUNT(DISTINCT val) over(PARTITION BY NAME) AS v
- FROM test_01)
- WHERE val IN (\'c\', /* \'d\',*/ \'e\');
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29507357/viewspace-1203918/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29507357/viewspace-1203918/