我在表中有此数据:
ID ItemID ItemSupplier 1 1 E 2 2 E 3 2 B 4 3 B 5 4 B 6 4 E 7 4 C 8 5 'NULL' 9 6 C 我想编写一个查询来选择它:
ItemID Supplier1 Supplier2 Supplier3 1 E 2 E B 3 B 4 B E C 5
6 C 但是我只能通过以下内容获得第一列:
SELECT ItemID, FIRST(ItemSupplier) AS Supplier1 FROM myTable GROUP BY ItemID
问题来源于stack overflow
MS Access不是为此的最佳工具。
一种方法使用相关子查询来枚举值,然后使用条件聚合:
select itemid, max(iif(seqnum = 1, itemsupplier, null)) as supplier_1, max(iif(seqnum = 2, itemsupplier, null)) as supplier_2, max(iif(seqnum = 3, itemsupplier, null)) as supplier_3 from (select t., (select count() from t as t2 where t2.itemid = t.itemid and t2.id <= t.id ) as seqnum from t ) as t group by itemid; 几乎所有其他数据库都支持窗口功能,这将使其效率更高。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。