gpt4 book ai didi

MySQL 多维从 View 中选择

转载 作者:行者123 更新时间:2023-11-29 07:08:37 25 4
gpt4 key购买 nike

我想显示逐年重新排列的数据,一种可能的解决方案是使用 View 并从中选择。数据矩阵是这样的(当然这是一个虚构的演示数据集):

USA  2005  22  156
CAN 2005 14 101
MEX 2005 5 32
USA 2006 24 160
CAN 2006 16 103
USA 2007 26 163
MEX 2007 8 35

创建和填充表的 SQL 代码是:

DROP TABLE IF EXISTS `tab1`;<br>
CREATE TABLE `tab1` ( <br>
`id1` int(4) unsigned NOT NULL AUTO_INCREMENT,
`iso3` char(3) NOT NULL,
`year` int(4) unsigned NOT NULL,
`aaa` int(10) DEFAULT NULL,
`bbb` int(10) DEFAULT NULL,
PRIMARY KEY (`id1`)
)


INSERT INTO `tab1` VALUES
('1', 'USA', '2005', '22', '156'),
('2', 'CAN', '2005', '14', '101'),
('3', 'MEX', '2005', '5', '32'),
('4', 'USA', '2006', '24', '160'),
('5', 'CAN', '2006', '16', '103'),
('6', 'USA', '2007', '26', '163'),
('7', 'MEX', '2007', '8', '35');
COMMIT;

现在我想为参数“aaa”获取一个二维表,如下所示:

country 2005 2006 2007 
USA 22 24 26
CAN 14 16
MEX 5 8

但是下面的 SQL 代码省略了所有缺少数据的行,即使是一个值,我也只得到一行

 USA    22  24  26

SQL代码为:

 SELECT view2005.Country, view2005.2005, view2006.2006, view2007.2007 
FROM view2005, view2006, view2007
WHERE view2005.country = view2006.country
AND view2005.country = view2007.country

知道如何做到这一点,包括缺少数据的行吗?提前致谢。

最佳答案

使用左连接和具有所有不同国家/地区的 View (或表,或内部选择,如下所示):

SELECT c.country, view2005.2005, view2006.2006, view2007.2007 
FROM (SELECT DISTINCT country FROM tab1) as c
LEFT JOIN view2005 ON view2005.country = c.country
LEFT JOIN view2006 ON view2006.country = c.country
LEFT JOIN view2007 ON view2007.country = c.country
GROUP BY c.country

编辑:

在更一般的上下文中,您在这里要求的是创建此表的数据透视表,这是一个具有通用解决方案的常见问题。这是一个不错的“操作方法”:http://www.artfulsoftware.com/infotree/queries.php?&bw=1339#78

关于MySQL 多维从 View 中选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5872115/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com