当前位置: 首页 > 面试题库 >

有没有办法在不使用CASE的情况下将行旋转到列?

丁学
2023-03-14
问题内容

关于将行旋转为各种数据库的列,有很多文章。他们似乎分为两个阵营,使用案例语句或使用数据库供应商的内置功能。我正在使用 MySQL
,到目前为止,尚未在任何内置函数上找到任何东西,该函数使我可以选择任意数量的行值(希望将其转换为列)。如果我不提前知道这些值,则无法构建经常出现在stackoverflow上的CASE查询。我想知道MySQL中是否有类似于其他数据库中称为交叉表或数据透视表的东西:

-Postgresql: http
//www.postgresql.org/docs/current/static/tablefunc.html -Oracle:
http :
// www.oracle-
base.com/articles/11g/PivotAndUnpivotOperators_11gR1.php
-SQL Server: http: //msdn.microsoft.com/zh-CN/library/ms177410.aspx

只是为了确保当我说将数据透视表转换为列时,我想清楚我要的是什么,我想像这样转换一个表

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十分费力。



 类似资料:
  • 问题内容: 关于将行旋转为各种数据库的列,有很多文章。他们似乎分为两个阵营,使用案例陈述或使用数据库供应商的内置功能。我正在使用 MySQL ,到目前为止,在任何内置函数上都找不到任何东西,这将使我能够选择任意数量的行值(我想将其转换为列)。如果我不提前知道这些值,则无法构建经常出现在的CASE查询。我想知道在MySQL中是否有类似于其他数据库中称为交叉表或数据透视表的东西: -Postgresq

  • 使用PHP-PDO和SQLite,我可以编写一个PDO调用来检查表中是否存在某一行(通过检查主键),如果不存在,则编写另一个PDO调用来创建该行。但我觉得应该可以在一个命令中实现……类似于“如果不存在,则创建表”。是否有类似“不存在时插入行”的内容?

  • 所以我想要一个“Void Repository”,通过它可以访问不一定在实体上操作的存储过程。 但这当然不起作用,因为期望是一个实体。 有没有一种方法可以使用注释而无需创建虚拟实体,或者我是否坚持使用使用通过准备好的语句进行查询的已实现类? 因为老实说,这很难看:

  • 问题内容: 我有一种方法可以做很多事情。其中包括进行大量插入和更新。因此宣布… 它的工作完全符合预期,我对此没有任何问题。但是在某些情况下,尽管没有异常,但我还是想强制回滚…目前,当我遇到合适的条件时,我正在强制异常,但这很丑陋,我不喜欢它。 我可以以某种方式积极地调用回滚吗?异常调用它…我在想也许我也可以。 问题答案: 在Spring Transactions中,您使用。 您在这里遇到的问题是您

  • 问题内容: 我正在开发一个简单的Webapp,它将域模型公开为RESTful资源。我打算将JPA2(Hibernate)与SpringMVC REST支持一起使用。 在将Hibernate实体编组为XML / JSON时,如果该实体分离,它将为惰性子项关联抛出LazyLoadingException。如果实体仍然连接到Hibernate Session,它将几乎加载整个数据库。 我尝试使用推土机C

  • 问题内容: 使用JSch,有没有办法在不执行ls并循环浏览文件以查找名称匹配的情况下,确定是否存在远程文件? 谢谢 问题答案: (这是如果您使用的是库的SFTP部分,这是我没有考虑的假设。) 我以为它会接受文件名。我目前无法检查。 如果不是这样,则无需手动进行迭代。您可以使用选择器变体: