位置: 编程技术 - 正文

mysql 列转行的技巧(分享)(mysql sql行转列)

编辑:rootadmin

推荐整理分享mysql 列转行的技巧(分享)(mysql sql行转列),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql实现行转列,mysql怎么行转列,mysql sql行转列,mysql sql行转列,mysql实现行转列,mysql实现行转列,mysql实现行转列,mysql行转列常用函数,内容如对您有帮助,希望把文章链接给更多的朋友!

前言:

由于很多业务表因为历史原因或者性能原因,都使用了违反第一范式的设计模式。即同一个列中存储了多个属性值(具体结构见下表)。

这种模式下,应用常常需要将这个列依据分隔符进行分割,并得到列转行的结果。

表数据:

ID Value 1 tiny,small,big 2 small,medium 3 tiny,big

期望得到结果:

ID Value 1 tiny 1 small 1 big 2 small 2 medium 3 tiny 3 big

正文:

原理分析:

这个join最基本原理是笛卡尔积。通过这个方式来实现循环。

以下是具体问题分析:

length(a.Size) - length(replace(a.mSize,',',''))+1 表示了,按照逗号分割后,改列拥有的数值数量,下面简称n

join过程的伪代码:

mysql 列转行的技巧(分享)(mysql sql行转列)

根据ID进行循环

{

判断:i 是否 <= n

{

获取最靠近第 i 个逗号之前的数据, 即 substring_index(substring_index(a.mSize,',',b.ID),',',-1)

i = i +1

}

ID = ID +1

}

总结:

这种方法的缺点在于,我们需要一个拥有连续数列的独立表(这里是incre_table)。并且连续数列的最大值一定要大于符合分割的值的个数。

例如有一行的mSize 有个逗号分割的值,那么我们的incre_table 就需要有至少个连续行。

当然,mysql内部也有现成的连续数列表可用。如mysql.help_topic: help_topic_id 共有个数值,一般能满足于大部分需求了。

改写后如下:

以上这篇mysql 列转行的技巧(分享)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

mysql列转行以及年月分组实例 如下所示:SELECTcount(DISTINCT(a.rect_id))zcount,a.job_dept,DATE_FORMAT(submit_date,'%Y-%m')zsubmit_dateFROM表名aWHEREa.statu=3ANDa.rstatu=2ANDa.job_deptIN('','','')GROUPBYa.job_dept,DATE

mysql 列转行,合并字段的方法(必看) 数据表:列转行:利用max(casewhenthen)max---聚合函数取最大值(casecoursewhen'语文'thenscoreelse0end)---判断as语文---别名作为列名SELECT`name`,MAX(CASEWHENcourse='语文'THEN

MySQL 5.7中的关键字与保留字详解 前言MySQL和Oracle的关键字还是不尽相同的,在Oracle数据库中,我们的数据表中定义了大量的code字段用来表示主键,但是在MySQL中code是关键字,使用以前

标签: mysql sql行转列

本文链接地址:https://www.jiuchutong.com/biancheng/349896.html 转载请保留说明!

上一篇:MySQL 按指定字段自定义列表排序的实现(mysql向指定字段中添加数据)

下一篇:mysql列转行以及年月分组实例(mysql怎么把列变成行)

  • 公司贷款可以转私人吗
  • 综合保税区内企业
  • 在建工程是负数时应该怎么处理
  • 企业出现税务问题的案例
  • 高铁费可抵扣适用税吗
  • 房产税的纳税义务
  • 收到外币货款的汇率
  • 工伤保险费发票
  • 资产处置损益和营业外收支的区别和联系
  • 交叉持股的合并财务报表
  • 土地在会计中怎么处理
  • 项目顾问是什么意思
  • 没有及时去做财务会计制度备案怎么办?
  • 应收账款抹零会计分录
  • 水费能不能开专票
  • 资源综合利用企业税收优惠
  • 模具是可以长期待摊吗
  • 苹果电脑型号怎么查
  • 如何安全的处置电子邮件
  • adsl灯一直闪烁
  • win10如何自定义鼠标指针
  • php文本转数字
  • dgservice.exe是什么
  • macos big sur 电池
  • 电脑dat文件怎么打开
  • 应收债权换入无形资产
  • 资产负债表应付账款怎么填列
  • php请求接口数据
  • php调用外部程序
  • php中类静态成员描述不正确的是
  • php处理xml数据
  • [深度学习] 基于切片辅助超推理库SAHI优化小目标识别
  • super命令linux
  • 小规模纳税人货款怎么算
  • 什么是债权人和债务人简单来说
  • 现金股利和现金利润的区别
  • 企业所得税季初和季末怎么算
  • 企业收到财政拨付的专项资金账务处理
  • 电子缴款凭证在哪里找
  • mysql 子查询
  • 期权费的合理范围计算
  • sqlserver重复数据
  • 应付账款的入账价值应当包括增值税的进项税额
  • 如何认定隐匿转移遗产
  • 信用减值损失是负数是什么意思
  • 红字冲销怎么做账
  • 固定资产一次性扣除后第二年账务处理
  • 未收到货款发票是什么意思
  • 土地转让需要批准吗
  • 电子商务中流量的定义
  • 国有资产无偿划转协议
  • 以前年度损益调整是什么意思
  • 旅行社差额征收怎么报税
  • 甲方代交水电费合法吗
  • 从法人借款现金分录
  • 企业的期间费用包括制造费用吗
  • 客户要扣货款太多怎么处理
  • win10+Ubuntu16.04 LTS双系统完美教程(图文教程)
  • netsh cmd
  • win1020h2正式版下载
  • linux做代理服务器的方法
  • linux系统安装软件教程
  • 深入理解bootstrap
  • 定制家具加盟品牌
  • jsforeach循环遍历数组
  • 请问在javascript程序中
  • js基础有哪些
  • shell 替换文件中匹配的内容
  • 批处理设置文件夹添加user组权限
  • js的脚本语言
  • 基于重大误解实施的民事法律行为
  • Python通过DOM和SAX方式解析XML的应用实例分享
  • 简述javascript的常用控制结构
  • shell删除一个文件
  • JavaScript数据类的特点
  • python提取信息
  • 饮料开专票几个点
  • 税务要求实名认证
  • 娱乐会所一般有什么
  • 舟山自贸区税收优惠政策五减五免
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设