位置: 编程技术 - 正文

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

  • 怎么查历年
  • 更正个税申报需要做账吗
  • 房屋租赁发票票样
  • 营业外收入在所得税表中填入哪个科目
  • 总分包外地施工怎样预缴税款?
  • 社保基数超过工资
  • 运输业增值税专用发票开具要求
  • 总公司业务分公司开票是虚开吗
  • 企业购买黄金如何处理
  • 电子普通发票需要盖章吗
  • 冲红发票开具
  • 退税记录显示税务审核中
  • 季度申报表营业成本怎么填
  • 公司注销无法支付的款项如何处理
  • 增值税如何计提和结转
  • 对公账户发工资的利弊
  • 固定资产更新改造替换部件怎么做账务处理
  • win10 0×0000007b怎么解决
  • Mac系统怎么设置ftp
  • 小规模纳税人个税怎么申报
  • 费用报销流程怎么走
  • win10好几个操作系统
  • json去除某个字段
  • 百香果的副作用及禁忌是哪些
  • find.exe应用程序错误
  • macOS Big Sur 11.3 开发者预览版/公测版 Beta 6正式发布
  • 电脑开机后桌面图标变乱
  • php7 数组
  • 工业企业在进行材料采购
  • 会计账簿的错账怎么办
  • vue组件继承并重写属性方法
  • CodeIgniter视图使用注意事项
  • vue如何学
  • 企业会计准则条文释义与案例详解
  • 布拉格下雪
  • vite搭建vue3
  • vue遍历数组
  • 机器学习中的数学原理——过拟合、正则化与惩罚函数
  • 命令行mkdir创建文件夹
  • 一字节的范围
  • 出版社出版带有编码吗
  • 固定资产清理怎么做账务处理
  • 差旅费抵扣所得税标准
  • 新办企业发票核定及申领
  • 个体工商户可以抵扣进项吗
  • 银行存款日记账填写样本图
  • 专项附加扣除哪种申报方式好
  • 对企业发票的监管
  • 预算会计与企业会计的区别感悟
  • 应交增值税结转账务处理
  • 账面价值大于计税基础是调增还是调减
  • 不抵扣进项税额转出怎么做分录处理
  • 无票利息支出可抵税吗
  • 注册资本认缴与注册登记实操
  • 购入厂部用小汽车一部是管理费用吗
  • 高新企业如何做账
  • 餐饮行业采购
  • 公司美元账户收款方便吗
  • 公司打款账号模板图片
  • 应收帐款坏账处理
  • macbookpro mysql
  • 行转列sql函数
  • sql中的视图提高了数据库的
  • mysql触发器语句
  • win7旗舰版怎么把桌面移动到其他盘
  • win10屏幕亮度怎么调节快捷键
  • ubuntu20.0安装
  • win10系统怎么设置电脑密码
  • linux 安装jmap
  • linux根目录和主目录
  • 阿里云ecs keepalived
  • ghost32命令参数
  • python函数enumerate
  • unity画面效果润色
  • js 正则replace
  • 安卓开发常见问题解决
  • Android 添加数据到本地Excel表
  • 虚拟摇杆 安卓
  • 国家税务局发票查验平台查验官网
  • 江苏电子票据
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设