您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

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

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

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

其他 2022/1/1 18:37:44 有600人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶