位置: 编程技术 - 正文

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

  • 年初存货跌价准备余额是上年末结转的吗
  • 房租收入怎么报税
  • 跨年增值税专用发票没有认证,需要开红字信息表吗
  • 个税为负数如何申报
  • 每天现金日记账登记完以后应怎么对账
  • 发票领购带什么
  • 差额征税怎么交税
  • 员工出差火车票可以抵扣进项吗
  • 贴现法付息什么意思
  • 减免增值税后附加税还用计提吗
  • 凭证可以部分冲销吗
  • 货币资金主要内容
  • 小规模专票冲红怎么操作
  • 油罐车运输费用怎么算
  • 年薪12万如何申报个人所得税
  • 金税盘用途
  • 城市垃圾处理费怎么申报
  • 非居民企业可以享受小微企业所得税优惠政策吗
  • 交易性金融资产入账价值怎么计算
  • harmonyos怎么打开OTG
  • windows10无线网卡怎么连接无线网
  • 净现值法的优点包括
  • 公司给员工交纳社保
  • 收到其他公司的罚款会计分录
  • 错账查找的方法
  • 鸿蒙2.0 更新
  • 公司出售已经提完折旧的机器
  • wind10待机唤醒
  • php preg_quote
  • php短链接api
  • vue中是如何划分的,每个区域的作用是什么
  • thinkphp3.0
  • vscode搭建vue开发环境
  • Web Spider Fiddler - JS Hook 基本使用
  • 语谱图生成
  • linux进程状态有哪些
  • 用php制作年历
  • php连接数据库步骤
  • 如何查看python模块的依赖包
  • 物流公司修理班的管理有那些书
  • 水果发票税率是几个点
  • 图文详解管道支架制作安装标准
  • 本年利润有余额是什么意思
  • 进项发票入账但没有发票
  • 抵扣联和发票联算一张发票吗
  • 长期待摊费用如何做分录
  • 企业所得税包含员工工资吗
  • 当月业务的发票可以次月开吗
  • 收到厂家返利如何计算成本
  • 所得税费用的账目处理
  • 收到货款发货了没开发票怎么入账
  • 累计折旧需要分录吗
  • 研发费用形成无形资产的摊销怎么处理
  • 报表的应付账款怎么算
  • 销售商品发生的运输费计入什么科目
  • 股东之间资金往来
  • 净资产收益率怎么算出来的
  • 存货周转率 高
  • mysql缩印
  • mysql怎么切换到bin目录
  • 回顾30年的水文模型参数率定研究
  • 在基于Xen的CentOS系统VPS上配置PPTP VPN的教程
  • ubuntu安装visual studio2019
  • ddriver进程
  • mac配置selenium
  • mac新版系统
  • iptables添加规则立即生效
  • 移动硬盘做win7系统盘
  • 如何删除win8系统
  • win10网速特别慢
  • opengl教学视频
  • node发送短信
  • js如何判断一个变量的类型
  • javascript运用
  • python res.
  • 华为税务筹划情况
  • 江苏高速通行费标准
  • 车船税优惠政策2022年
  • 如何查到银行
  • 英国个税税率最高
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设