位置: 编程技术 - 正文

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

  • 企业所得税年报怎么查询
  • 所得税费用怎么计提
  • 一般纳税人销售自己使用过的汽车
  • 先到发票后到商品怎么入账
  • 血液制品3%增值税税率
  • 稽查查补的税款用什么时候的税率表示
  • 怎样根据税负率调账
  • 加计扣除声明在哪里签章有效
  • 研究开发费用资本化和费用化
  • 先进技术企业的企业所得税税率
  • 房地产公司将自建自用房产出售 土地增值税
  • 丢失增值税发票最新处理办法
  • 企业政府性征地补偿款如何合法使用
  • 农产品增值税抵扣新政策2021
  • 契税差别
  • 投资理财产品怎么选
  • 水费收取违约金投诉回复
  • 原始凭证怎么做账
  • 单位风险金是什么意思
  • 偿债基金公司债
  • 预付账款是
  • 补缴的以前年度的税费及滞纳金用更正申报企业所得税吗
  • 有了营业执照就可以买社保了吗
  • 小微企业所得税优惠政策2023
  • 增值税小规模纳税人免征增值税政策
  • 汽修厂纳税多少
  • 外购机器设备
  • 待处理财产损益的二级科目
  • 咨询者对咨询师产生移情
  • 出口已使用过的设备退税吗
  • 资产负债率是用年初和年末数吗
  • mac outlook怎么设置邮箱签名
  • win11怎么关闭系统自动更新
  • mysql的minus
  • KbdTray.exe - KbdTray是什么进程 有什么作用
  • 皮肤痒怎么回事
  • php获取访问用户的ip
  • php 查找数组元素
  • 什么叫财政专户返还方式
  • 折旧和摊销的区别通俗
  • Windows7配置启用ca证书
  • upf命令
  • 跨期发票的形成条件
  • 企业合并的定义是什么
  • php去掉最后一个逗号
  • sql批量替换值
  • 医疗报销发票是什么样的
  • dedecms标签怎么用
  • 税务机关代开的增值税发票要加盖发票专用章吗?
  • 为什么结转材料成本差异
  • mysql 连接过多
  • mysql视图菜鸟教程
  • 其他综合收益会影响未分配利润吗
  • 生产经营个人所得税税率表
  • 发票已开款未到的会计分录?
  • 办公室搬迁工作
  • 承兑汇票利息分录
  • 辞退福利什么时候确认
  • 税控盘的主要功能包括
  • 货已经收到未收到怎么办
  • 应付账款的主要风险点
  • 无需缴纳的税费是什么
  • sql中存储过程的用法
  • drop table select
  • mysql数据库巡检脚本
  • win10快速启动什么意思
  • centos6.5配置网络
  • windowsxp怎么查看用户名密码
  • 磁盘限制
  • notify.exe - notify是什么进程 有什么用
  • win7专用字符编辑程序
  • Win7系统可以装ie10浏览器么
  • jQuery Validation PlugIn的使用方法详解
  • jquery的认识和使用
  • unity破解安装教程
  • bootstrap js插件
  • python遍历文件目录
  • 河北地方税务局吴瑜
  • 国税地税分开原因
  • 沥青进口需要配额吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设