位置: 编程技术 - 正文

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自带播放器不见了
  • 财政拨款收入的明细科目
  • arm on windows
  • 如何修复win11系统
  • pc程序是什么
  • 政府收回土地使用权免征增值税的条件
  • “网络爬虫”
  • 城镇土地使用税纳税义务发生时间
  • 因质量问题收取停工通知
  • 微信小程序开发完整项目
  • 已确认的发票如何入账
  • 买税控盘的钱怎么做账
  • cjzc框架
  • php curl_exec
  • RTX 4090深度学习性能实测奉上!模型训练可提升60~80%
  • 建行企业网上银行主管盾权限分配
  • 建筑装饰工程公司属于什么行业
  • 卖固定资产计入
  • python多态的概念
  • 小型微利企业季度所得税怎么计算
  • 法人怎么从公账上大量取钱
  • 财政拨入的专项款专账怎么做
  • 公司给非本单位的个人转账有风险怎么平账
  • 物业建车棚谁出钱
  • 增值税专用发票几个点
  • 公司账户转账转错了能退回来吗
  • 分包工程 税务 账务处理
  • 小规模企业发票税率是多少
  • 费用化资本化对税收的影响
  • 签劳动合同的员工有哪些
  • 公司现金支票取钱需要带什么资料
  • 公司流水账怎么做
  • 固定资产折旧怎么算
  • python的底层语言
  • sql server数据库怎么导出
  • vista win
  • ubuntu没有wlan0
  • ubuntu系统常用命令
  • bearshare.exe进程安全吗 bearshare是什么进程
  • windows右下角
  • win10注册表详解
  • .msc是什么文件
  • win10系统无法安装到gpt分区
  • win10右下角功能列表不见了
  • linux那些事儿
  • win8卸载软件在哪里卸载
  • linux查看多线程
  • Unity3D游戏开发(第2版)pdf
  • opengl常用函数库
  • 脚本控制三行三列怎么写
  • java使用jni
  • 原生js实现路由
  • 省市区三级联动下拉表单
  • ViewGroup onInterceptTouchEvent,ViewGroup onTouchEvent,View onTouchEvent执行顺序说明
  • 每天一篇文章锻炼口才的文章
  • python运行时间的几种方法
  • 吉林税务网上办事大厅
  • 税务核查是什么意思
  • 实木地板什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设