gpt4 book ai didi

mysql - 在不指定字段的情况下将行动态转换为列

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

如何在不指定行名称的情况下使用 Case 动态转换键值表?
例如,我将此表命名为 key_value:

id     key     value
1 name john
2 fname akbar
3 jobs Software enginer
. . .
. . .
. . .
. . .
. . .
n n n

我想将所有这些行动态转换为列而不指定键名,例如:

name   fname   jobs............................n
john akbar sofware engineer...........n

我用过:

Max(Case WHEN key='name' THEN value END) AS name

在这个查询中我知道我的 key 。
如果我不知道我的字段,也不知道我有多少个字段怎么办?

我想在不指定我的字段的情况下动态转换所有这些。

最佳答案

这也是我之前的问题
SQL Query fields as columns
我修改了它来回答你的问题,我希望它能像对我一样有所帮助!

SET @sql = NULL;
SELECT
GROUP_CONCAT(DISTINCT
CONCAT(
'MAX(IF(a.xvalue = ''',
xvalue,
''', a.xvalue, NULL)) AS ',
xkey
)
) INTO @sql
FROM key_value;


SET @sql = CONCAT('SELECT ', @sql, '
FROM key_value a
LEFT JOIN key_value AS b
ON a.id=b.id');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

SQL Fiddle

关于mysql - 在不指定字段的情况下将行动态转换为列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18931396/

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