+ -
当前位置:首页 → 问答吧 → 新手求助,一个SQL不会写了

新手求助,一个SQL不会写了

时间:2011-08-31

来源:互联网

一个表里有fs_type和export两个字段
写SQL, 相同fs_key对应的几个export中,有'A'就输出'A',没有就输出第一个值

我的想法是
SELECT fs_key,
  与export相关计算
FROM tb_filesystem_export_cifs
group by fs_key;

可是卡在export相关计算那地方了,怎么也想不出该怎么写...

PostgreSQL

作者: alan_chen222   发布时间: 2011-08-31

贴数据及要求结果贴出来看看

作者: WWWWA   发布时间: 2011-08-31

SELECT fs_key, min(export)
FROM tb_filesystem_export_cifs
group by fs_key;

作者: ACMAIN_CHM   发布时间: 2011-08-31

我是楼主,重新整理了一下

一个表里有fs_key和export两个字段
 写SQL, 相同fs_key对应的几个export中,有'A'就输出'A',没有就输出第一个值
 fs_key | export
----------------
1 | 'B'
1 | 'A'
2 | 'C'
2 | 'D'
 输出AC

由于ABCD都是例子,实例中都是复杂字符串。。所以楼上min()并不能用...

作者: alan_chen222   发布时间: 2011-08-31

输出“AC”这么个字符串? 无法理解你的需求了。

  建议你列出你的表结构,并提供测试数据以及基于这些测试数据的所对应正确结果。
  参考一下这个贴子的提问方式http://topic.csdn.net/u/20091130/20/8343ee6a-417c-4c2d-9415-fa46604a00cf.html
   
  1. 你的 create table xxx .. 语句
  2. 你的 insert into xxx ... 语句
  3. 结果是什么样,(并给以简单的算法描述)
  4. 你用的数据库名称和版本(经常有人在MS SQL server版问 MySQL)
   
  这样想帮你的人可以直接搭建和你相同的环境,并在给出方案前进行测试,避免文字描述理解上的误差。

 

作者: ACMAIN_CHM   发布时间: 2011-08-31

加入自增字段ID
SELECT * FROM TTH1 A WHERE NOT EXISTS(SELECT 1 FROM TTH1 WHERE A.fs_key=fs_key AND export='A') AND 
NOT EXISTS(SELECT 1 FROM TTH1 WHERE A.fs_key=fs_key AND A.ID>ID)
UNION ALL
SELECT * FROM TTH1 A WHERE EXISTS(SELECT 1 FROM TTH1 WHERE A.fs_key=fs_key AND A.export='A')

作者: WWWWA   发布时间: 2011-08-31