关于将行旋转为各种数据库的列,有很多文章。他们似乎分为两个阵营,使用案例语句或使用数据库供应商的内置功能。我正在使用 MySQL ,到目前为止,尚未在任何内置函数上找到任何东西,该函数使我可以选择任意数量的行值(希望将其转换为列)。如果我不提前知道这些值,则无法构建经常出现在stackoverflow上的CASE查询。我想知道MySQL中是否有类似于其他数据库中称为交叉表或数据透视表的东西:
只是为了确保当我说将数据透视表转换为列时,我想清楚我要的是什么,我想像这样转换一个表
user_id键值 鲍勃棕色的 鲍勃眼睛蓝色 杰克头发棕色 杰克高度6‘2“
变成这个:
user_id头发眼睛身高 鲍勃·布朗蓝色 杰克·布朗6‘2“
我正在特别寻找 MySQL中 的解决方案,因此,如果您有任何特定的新数据库或新数据库可以解决此问题,将不胜感激。
Kangkan提供的链接将向您展示如果您事先知道列名,该如何实现。除了使用动态SQL生成语句外,我们将采用相同的逻辑。每个字段都需要包括两部分,select语句中的字段和获取值的适当联接…所以我们需要分两部分构建语句
首先声明3个变量来构建它…在本示例中,我将使用@ select,@ join和@sql。给变量初始值
set @select = 'select user_id,' set @join = 'from table t'
现在,在table.key字段中声明并加载具有不同值的游标。我将使用@field,因为变量使用独特的table.key字段填充。然后遍历它,构建两个变量:
set @select = @select + ', ' + @field + '.value as '+@field+' set @join = @join + ' left join table ' + @field + 'on '+@field+'.key = t.key and and '+@field+'.user_id = t.user_id
(该联接被设计为使用@field中的值作为表的别名)
遍历光标,构建出@select和@join。在循环结束时:
set @sql = @select + @join + 'where clause if you want' exec @sql
像这样构建的动态SQL绝对是麻烦解决(并解决问题)和公开安全问题的痛苦……但这是我看到这一点的唯一途径。注意变量的大小限制。…如果那里有太多不同的键,则变量会变得太大。抱歉,我无法更准确地使用伪代码…您会发现在sql中构建动态sql十分费力。