相关疑难解决方法(0)

如何使用SQL将垂直数据转换为水平数据?

我有一个表"项目",其中包含许多相关项目,如下所示:

ID   Rel_ID  Name  RelRank
---  ------  ----  -------
1    1       foo   1
2    1       bar   2
3    1       zam   3
4    2       foo2  1
Run Code Online (Sandbox Code Playgroud)

我正在尝试获取查询,因此具有相同Rel_ID的项目将出现在同一行中,如下所示:

Rel_ID  Name1  Name2  Name3
------  -----  -----  -----
1       foo    bar    zam
2       foo2
Run Code Online (Sandbox Code Playgroud)

我尝试过多次选择表格:

SELECT k.Rel_ID, k.name 'Name1', k2.name 'Name2'
FROM item k, item k2
WHERE k.Rel_ID = k2.Rel_ID
Run Code Online (Sandbox Code Playgroud)

但这失败了.当然有一个转换或查询可以大大简化过程,我只是错过它,因为我之前没有以这种方式使用SQL.我错过了什么?

[编辑:添加了RelRank列,确实出现在我的数据中]

mysql sql pivot

18
推荐指数
1
解决办法
7万
查看次数

Mysql查询查找一个列的多个条件满足的ID

我将不胜感激任何创建此查询的帮助.我没试过好几种方法.由于我的问题对我来说有点困难,我将简单举例说明我想做什么.我的数据结构与以下内容类似:

ID  TYPE  COLOR
1   A     Blue
1   B     Red
1   C     Green
2   C     Blue 
2   B     Green 
Run Code Online (Sandbox Code Playgroud)

如果我有一个具有两种特定颜色的ID,我想创建一个返回类型的查询.例如,我想找到所有同时具有蓝色和红色的ID.然后查询将返回:

1, A , B 
Run Code Online (Sandbox Code Playgroud)

返回A和B的顺序并不重要.数据集很大,我希望很多ID都符合这两个条件(可能是50,000左右).我应该注意,该类型与颜色无关,因此使问题与其他stackoverflow问题不同,以及这个问题.

我想我需要做某种子查询.但真的不知道该怎么办,谢谢.

mysql sql select

2
推荐指数
1
解决办法
4322
查看次数

标签 统计

mysql ×2

sql ×2

pivot ×1

select ×1