sql server Oracle中的一个sql 题目 99%的人写不出来

原题来自: http://sqlyuju.com/sql-server-oracle-nanti1.html

数据显示如下:

QQ%E6%88%AA%E5%9B%BE20140307125440.jpg

建表语句:

点击(此处)折叠或打开

  1. create table test(
  2. name varchar(20),
  3. val varchar(20)
  4. );
  5. insert into test(name,val) values (\'小红\',\'c\');
  6. insert into test(name,val) values (\'小红\',\'d\');
  7. insert into test(name,val) values (\'小红\',\'e\');
  8. insert into test(name,val) values (\'小李\',\'c\');
  9. insert into test(name,val) values (\'小李\',\'e\');
  10. insert into test(name,val) values (\'小白\',\'c\');
  11. insert into test(name,val) values (\'小白\',\'d\');
  12. insert into test(name,val) values (\'小黑\',\'d\');
  13. commit;
------问题----

--1、查询 val 为 c d e 的 只能找到 小红

--2、查询 val 为 c e 的 只能找到 小红 小李(如果只显示小李,又怎么写)

注意:上面其实是一个sql 传入不同的参数 如 'c','d','e' 或是 'c','e'

要求:sql server 语法 或是 Oracle 语法。

Oracle 实现:


点击(此处)折叠或打开

  1. select *
  2.   from (select name,
  3.                count(distinct val) over() as c,
  4.                count(distinct val) over(partition by name) as v
  5.           from test_01
  6.          where val in (\'c\', \'d\', \'e\'))
  7.  where c = v;

  8. ----只显示小李

  9. SELECT NAME, v, COUNT(DISTINCT val) over(PARTITION BY NAME) AS v2
  10.   FROM (SELECT NAME, val, COUNT(DISTINCT val) over(PARTITION BY NAME) AS v
  11.           FROM test_01)
  12.  WHERE val IN (\'c\', /* \'d\',*/ \'e\');

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29507357/viewspace-1203918/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29507357/viewspace-1203918/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值