位置: 编程技术 - 正文

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怎么把列变成行)

  • 企业所得税当年销售收入
  • 小规模纳税人已过开票截止日期禁止开票怎么办
  • 运费增值税税率有5吗
  • 公司购买股票如何做账
  • 2021年9月个税申报截止时间
  • 行政单位的财务报告包括财务报表和财务情况说明书
  • 预存1000送100促销活动方案
  • 未投入使用的道路
  • 房产税应由哪方交纳
  • 支付稿费演出费用怎么算
  • 运保佣是什么
  • 上月多计收入,本月如何调整?
  • 购进免税农产品怎么计算进项税额
  • 退休人员是否还继续享受社保
  • 增值税专用发票电子版
  • 发票认证了还能退回吗
  • 支付的各项税费包括个人所得税吗
  • 个体工商户个人所得税怎么计算
  • 装修期间用电
  • 双倍余额折旧法
  • 未分配利润转增股本要交税吗
  • ie浏览器打开后显示已停止工作
  • windows10 20h2 2004
  • 小微企业财务报表报送时间
  • 无法连接到移动网络小米
  • linux swap 0
  • 技术服务辅助设施包括
  • 本年利润和利润总额的关系
  • 超率累进税率和超倍累进税率
  • code ide
  • 如何用ai写代码
  • 建筑企业跨区域还需预缴增值税吗
  • 库存商品损失怎么做账
  • 出口换汇成本一般是多少
  • 增值税纳税人如何界定
  • php的foreach循环语句
  • 面试宝典下载
  • php生成唯一字符串
  • 农产品进项税抵扣填报方法
  • 购进农产品直接销售核定农产品增值税进项税额计算表
  • 补开上年发票的税务处理要怎么做?
  • mongodb自增主键
  • 公司银行开户的经办人有无风险
  • 年金保险是指什么保险
  • mysql交互操作过程中使用的语言是什么
  • mysql 索性
  • 企业存续情况
  • 未分配利润是否可以全部分红
  • 运费与快递费的区别在哪
  • 何为居民企业
  • 社保应该如何缴纳
  • 计提印花税会计分录怎么写
  • 事业单位非税收入帐务处理
  • 被收购企业账务处理流程
  • 金税盘每年服务费可以抵扣吗
  • 普通发票和增值税发票的区别图片
  • 采购人员垫付怎么入账
  • mysql基础概念
  • linux 清理
  • 禁止windows安装程序
  • windows10周年更新
  • xp 注册
  • win7系统删除文件夹怎么恢复
  • win7怎么删除除了系统盘所有东西
  • unity的粒子系统在哪
  • js调用xml
  • 详解JavaScript ES6中的Generator
  • scrollview用法
  • Python中str is not callable问题详解及解决办法
  • windows and android
  • android源码分析
  • 安卓手机管家下载
  • 怎么用js实现滑动效果
  • js常用继承
  • 浙江省税务局领导介绍
  • 重庆国税电子税务登录
  • 加油河南app怎么注销
  • 国外高速公路收费站
  • 怎么删除天眼查的犯罪记录
  • 税收超额负担图解
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设