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

有没有一种方法可以在不使用CASE的情况下将行旋转到列中?

艾鹭洋
2023-03-14
问题内容

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

  • 我想在我的spring web应用程序中添加几个过滤器,但至少现在不会有任何关于安全性的内容。所以。没有spring-security我所能做的就是在web.xml中定义多个过滤器(定义过滤器的旧方法)。要能够使用spring过滤器链,我需要为我的项目添加spring-security作为依赖项,这似乎很奇怪。也许我做错了什么,而且确实有过滤器链可以在没有spring-security依赖的情况下

  • 我被困在一个Java编码任务中。我应该为现有程序创建三种方法(,,和),让用户将数字输入数组,然后组织并打印该数组接收数组作为参数,向用户请求索引值,并将输入的数字量返回为int。将值复制到一个新数组中,该数组的长度为返回的数字量,对数字进行排序。 我的问题是,根据作业,应该只返回输入的数字量。因此,它将打印的数组值留在方法内部,使得无法检索这些值并将其复制到第二个数组中。如果没有编辑主方法的能力

  • 问题内容: 我想构建一个PHP脚本来验证SQL查询,但不执行它。它不仅应验证语法,而且还应在可能的情况下让您知道是否可以通过查询中的命令来执行查询。这是我想要执行的操作的伪代码: 这样的事情。我希望它模拟查询而不执行它。那就是我想要的,对此我什么也找不到。 为什么我们不希望执行查询的一个示例是,如果查询向数据库中添加了一些内容。我们只希望它在不修改数据库的情况下对其进行仿真。 任何链接或示例将不胜

  • 我试图使用confluent的模式注册表使我的应用程序工作,但此时我并不是生产者的完全控制者,你甚至可以将它们视为不绑定confluent产品的遗留应用程序。 我正在查看融合信息,似乎所有消息都应该在有效负载中包含一个魔法字节和模式ID https://docs.confluent.io/3.2.0/schema-registry/docs/serializer-formatter.html 或者

  • 我有一个Spring Boot应用程序,注释为。几乎所有的存储库都需要实现一些自定义逻辑,这是使用完成的。 是否有方法创建将从机制中排除的存储库?