博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql行转列(拆分字符串场景)
阅读量:6154 次
发布时间:2019-06-21

本文共 520 字,大约阅读时间需要 1 分钟。

hot3.png

一对多没有建立中间表的时候经常会采用分隔符的形式将“多”存储在“一”的一个字段里,这样做的代价是无法向一对多的时候那样直接关联查询,一般采用在程序中分割后分别查询的办法。如下图:

如何才能直接用sql语句查询出下图的效果呢?

可以借助一个序号表,该表中除了连续的id没有其它字段,id的值范围取决于"一"中存储的信息拆分后的数量。

实现sql:

SELECT	NAME,	REPLACE(		SUBSTRING_INDEX(mobile, ',', a.id),		CONCAT(			SUBSTRING_INDEX(mobile, ',', a.id - 1),			','		),		''	)AS mobileFROM	squence aCROSS JOIN(	SELECT		NAME,		CONCAT(mobile, ',')AS mobile,		LENGTH(mobile)- LENGTH(REPLACE(mobile, ',', ''))+ 1 AS size	FROM		`user`)b ON a.id <= b.size

转载于:https://my.oschina.net/u/1427708/blog/710603

你可能感兴趣的文章
正则表达式的语法规则
查看>>
C#一个关于委托和事件通俗易懂的例子
查看>>
类似于SVN的文档内容差异对比工具winmerge
查看>>
Cause: java.sql.SQLException: The user specified as a definer ('root'@'%') does not exist
查看>>
quratz线程
查看>>
execnet: rapid multi-Python deployment
查看>>
windows修改3389端口
查看>>
关于JavaScript词法
查看>>
FreeSwitch中的会议功能(4)
查看>>
MySQL中创建用户分配权限(到指定数据库或者指定数据库表中)
查看>>
AutoReleasePool 和 ARC 以及Garbage Collection
查看>>
重新想象 Windows 8 Store Apps (9) - 控件之 ScrollViewer 基础
查看>>
乐在其中设计模式(C#) - 提供者模式(Provider Pattern)
查看>>
MVP Community Camp 社区大课堂
查看>>
GWT用frame调用JSP
查看>>
大型高性能ASP.NET系统架构设计
查看>>
insert select带来的问题
查看>>
EasyUI 添加tab页(iframe方式)
查看>>
mysqldump主要参数探究
查看>>
好记心不如烂笔头,ssh登录 The authenticity of host 192.168.0.xxx can't be established. 的问题...
查看>>