iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >SQL 如何实现动态的行列转置
  • 753
分享到

SQL 如何实现动态的行列转置

SQL如何实现动态的行列转置 2015-04-20 11:04:48 753人浏览 绘本
摘要

oracle 和新版 Mysql 里有 pivot 实现行列转置,但实际处理数据时,会碰到一些更复杂的转置情况,pivot 也搞不定,比如: 想转置成: 这个难点在于事先不知道有多少种收入来源,而且每个人的收入来源种类各不相同。

SQL 如何实现动态的行列转置

oracle 和新版 Mysql 里有 pivot 实现行列转置,但实际处理数据时,会碰到一些更复杂的转置情况,pivot 也搞不定,比如:

1png

想转置成:

2png

这个难点在于事先不知道有多少种收入来源,而且每个人的收入来源种类各不相同。先得计算出种类个数,根据个数动态生成表结构,然后按照顺序填充每个人的多个收入数据。

sql 的计算过程不提倡分步,对集合操作支持的也不彻底,很难应付这种多步骤复杂计算。

如果用集算器的 SPL 语言来处理,就能轻松实现:

  A B
1 =connect("db") =A1.query("select * from Income")
2 =B1.group(Name) =A2.max(~.len())
3 =create(Name,${B2.("Source"+string(~)+",Income"+string(~)).concat@c()})  
4 for A2 =A4.Name|A4.conj([Source,Income])
5   >A3.record(B4)

A3 格子根据原始数据得到期望数据结构的空表;B4 格子得到每个人要填充入空表的数据。

如果不用复杂计算得到结果列,只是根据某个字段值动态生成列,直接用 pivot 函数就可以;具体的列都不用指定,根据字段值自动生成:
=connect(”mysqlDB”).query(“select * from t”).pivot(g1;g2,f)。

除了动态行列转置,还有双向转置、转置同时存在列间运算等复杂转置需求,这些计算用 SPL 都容易编写出来,参考《转置》。

 

集算器 SPL 是解决 SQL 难题的专业脚本语言,它语法简单,符合自然思维,是天然分步、层次清晰的面向过程计算语言。它采用与数据库无关的统一语法,编写的算法可在数据库间无缝迁移。它是桌面级计算工具,即装即用,配置简单,调试功能完善,可设置断点、单步执行,每步执行结果都可查看。请参阅SQL 解题手

当数据不在数据库里时,SPL 执行复杂计算仍然方便:
=file(“d:/t.csv”).import(;,",").pivot...

SPL能很方便地嵌入到JAVA应用,可参考《Java 如何调用 SPL 脚本》。

具体使用方法可参考 《如何使用集算器》。

您可能感兴趣的文档:

--结束END--

本文标题: SQL 如何实现动态的行列转置

本文链接: https://www.lsjlt.com/news/6364.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SQL如何实现行转列和列转行
    这篇文章给大家分享的是有关SQL如何实现行转列和列转行的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。行列互转,是一个经常遇到的需求。实现的方法,有case when方式和2005...
    99+
    2024-04-02
  • mysql动态行转列怎么实现
    在MySQL中将动态行转列可以使用GROUP_CONCAT函数以及动态SQL语句来实现。以下是一个示例代码: 假设有一个表格名为da...
    99+
    2024-04-09
    mysql
  • sql语句如何实现行转列
    这篇文章将为大家详细讲解有关sql语句如何实现行转列,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言一般在做数据统计的时候会用到行转列,假如要统计学生的成绩,数据库里查...
    99+
    2024-04-02
  • Excel中怎么实现动态行转列
    这篇文章将为大家详细讲解有关Excel中怎么实现动态行转列,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。查询的SQL如下<ol start="...
    99+
    2024-04-02
  • SQL中如何实现行转列Pivot函数
    这篇文章将为大家详细讲解有关SQL中如何实现行转列Pivot函数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。先来创建一个DailyIncome 表create ...
    99+
    2024-04-02
  • 怎么在SQL中实现行转列和列转行
    怎么在SQL中实现行转列和列转行?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。行列转换就是如下图所示两种展示形式的互相转换行转列假如我们有...
    99+
    2024-04-02
  • Vue动态生成表格的行和列如何实现
    本篇内容主要讲解“Vue动态生成表格的行和列如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue动态生成表格的行和列如何实现”吧!具体的实现代码如下:<template>&n...
    99+
    2023-07-04
  • Pandas.DataFrame行和列的转置的实现
    目录pandas.DataFrame.Tpandas.DataFrame.transpose()修改原始对象本身当进行类型转换(广播)时视图和复制如果要交换(转置)pandas.Da...
    99+
    2023-02-22
    Pandas DataFrame行列转置 Pandas.DataFrame行列交换
  • SQL Server如何使用PIVOT与unPIVOT实现行列转换
    这篇“SQL Server如何使用PIVOT与unPIVOT实现行列转换”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这...
    99+
    2023-06-30
  • sql实现列转行的方法是什么
    在SQL中,可以使用UNPIVOT操作符来实现列转行的功能。UNPIVOT操作符可以将多个列转换为行,将多个列的值转换为行的值,并将...
    99+
    2024-04-15
    sql
  • 如何进行SQL中PIVOT行列转换
    这篇文章主要讲解了“如何进行SQL中PIVOT行列转换”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何进行SQL中PIVOT行列转换”吧!PIVOT通过将...
    99+
    2024-04-02
  • C# DataGridView行列转换如何实现
    这篇文章主要讲解了“C# DataGridView行列转换如何实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C# DataGridView行列转换如何实现”吧!初始表...
    99+
    2023-07-05
  • Pandas.DataFrame行和列如何转置
    本篇内容主要讲解“Pandas.DataFrame行和列如何转置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Pandas.DataFrame行和列如何转置”吧!如果要交换(转置)pandas....
    99+
    2023-07-05
  • MySQL动态行转列的作用是什么
    MySQL动态行转列的作用是将行数据转换为列数据,使数据在展示时更加直观和易于理解。通过动态行转列,可以将数据按照某种规则动态地排列...
    99+
    2024-04-09
    mysql
  • spring schedule如何实现动态配置执行时间
    本篇内容介绍了“spring schedule如何实现动态配置执行时间”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!spring sched...
    99+
    2023-06-25
  • Java动态循环队列是如何实现的
    目录一、队列1.1 定义1.2 抽象数据类型1.3 顺序存储二、数组队列2.1 思路分析2.2 代码实现2.3 数组队列实现2.4 分析三、环形队列3.1 思路分析3.2 代码实现3...
    99+
    2024-04-02
  • ios开发中如何实现模态跳转的动画设置
    这篇文章主要介绍ios开发中如何实现模态跳转的动画设置,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!模态跳转的动画设置设置模态跳转的动画,系统提供了四种可供选择DetailViewC...
    99+
    2024-04-02
  • SQL中如何将行转成列详解
    目录SQL中怎么将行转成列?1. 使用 CASE…WHEN…THEN 语句实现行转列,参考如下代码:2. 使用 IF() 函数实现行转列,参考如下代码:补...
    99+
    2022-11-13
    sql怎样将列转为行 sql 行列转换 sql语句行转列
  • unity如何实现动态排行榜
    这篇文章给大家分享的是有关unity如何实现动态排行榜的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在做2048游戏的时候要实现排行榜的功能:超出显示范围可以通过滑动滚动条来上下查看2.动态插入行3.每次插入自动...
    99+
    2023-06-20
  • python如何实现Excel多行多列的转换
    今天小编给大家分享一下python如何实现Excel多行多列的转换的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、使用需求...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作