MySQL动态列转行

介绍​​

在实际的数据库查询中,有时候我们需要将表中的动态列(即列数不固定)转换为行,以便更好地进行数据分析和展示。在MySQL中,可以通过使用一些技巧和函数来实现动态列转行的功能。本文将介绍怎么实现MySQL动态列转行。

初始表

首先,假设我们有一个表格 users,其中需要动态的列 create_time,我们希望将该列转换为行。下面是一个示例表格的结构:

# 创建用户表
DROP TABLE IF EXISTS users;
CREATE TABLE users
(
    id          INT PRIMARY KEY auto_increment COMMENT '主键',
    username    VARCHAR(30) NOT NULL COMMENT '用户名',
    password    VARCHAR(30) NOT NULL COMMENT '密码',
    nickname    VARCHAR(30) COMMENT '昵称',
    phone       VARCHAR(11) COMMENT '电话号码',
    create_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    update_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间',
    is_deleted  INT      DEFAULT 0 COMMENT '逻辑删除(1:已删除,0:未删除)'
) COMMENT '用户信息表';

# 插入数据
INSERT INTO users (username, password, nickname, phone, create_time)
VALUES ('admin', 'admin', '张三', '18955554444', '2023-05-01 22:48:11'),
       ('root', 'root', '李四', '17755624235', '2023-05-02 22:48:11'),
       ('lisi', 'lisi', '王五', '15989654123', '2023-05-03 22:48:11'),
       ('lucky', 'lucky', '赵六', '19956852548', '2023-05-04 22:48:11'),
       ('admin2', 'admin', '张三', '18955554444', '2023-05-01 22:48:11'),
       ('root2', 'root', '李四', '17755624235', '2023-05-02 22:48:11'),
       ('lisi2', 'lisi', '王五', '15989654123', '2023-05-01 22:48:11'),
       ('lucky2', 'lucky', '赵六', '19956852548', '2023-05-01 22:48:11');

想要的效果:

​​​image

通过 格式化日期+计数函数+分组 实现

select DATE_FORMAT(create_time,'%Y/%m/%d') as create_date, count(*) as sum from users group by create_date

执行结果:
在这里插入图片描述
显然这并不是我们想要的效果。 这时候就需要用到动态列转行了。

通过 格式日期+求和函数 实现

SELECT
	SUM( DATE_FORMAT( create_time, '%Y/%m/%d' ) = '2023/05/01' ) AS '2023/05/01',
	SUM( DATE_FORMAT( create_time, '%Y/%m/%d' ) = '2023/05/02' ) AS '2023/05/02',
	SUM( DATE_FORMAT( create_time, '%Y/%m/%d' ) = '2023/05/03' ) AS '2023/05/03',
	SUM( DATE_FORMAT( create_time, '%Y/%m/%d' ) = '2023/05/04' ) AS '2023/05/04' 
FROM
	users

执行结果:
在这里插入图片描述
这样就达到我们要的效果了。但是有局限性,如果在加一个日期就需要改SQL。

通过 存储过程+分组合并函数+SQL拼接 实现

# 设置结束分隔符
DELIMITER $$
# 判断定义的存储过程是否存在,存在删除,以防存储过程存在报错
DROP PROCEDURE IF EXISTS pro$$ 
# 创建存储过程
CREATE PROCEDURE pro () BEGIN
  # 定义一个变量
  SET @SQL = NULL;
	# 把查询的日期赋给变量
	# 这里需要将日期格式化一下, 我要的格式是yyyy/MM/dd,
	# 而数据给我们的是yyyy-MM-dd HH:mm:ss
	SELECT
		GROUP_CONCAT( DISTINCT CONCAT( 'SUM(DATE_FORMAT(create_time, \'%Y/%m/%d\') = ''', 
		DATE_FORMAT( create_time, '%Y/%m/%d' ), ''') AS ''',          
		DATE_FORMAT( create_time, '%Y/%m/%d' ), '''' ) ) INTO @SQL 
	FROM users;
	# 注意:如果运行时报错可以执行
	# SELECT @SQL;
	# 检查拼接的SQL是否正确
	# 拼接sql
	SET @SQL = concat( 'select ', @SQL, ' from users' );
	# 预处理语句
	PREPARE stmt FROM	@SQL;
	# 执行
	EXECUTE stmt;
	# 销毁
	DEALLOCATE PREPARE stmt;
# 结束
END $$ 

 # 调用存储过程
CALL pro ();

为了方便测试在插入一笔数据

INSERT INTO users (username, password, nickname, phone, create_time)
VALUES ('test', 'test', 'test', '18955554844', '2023-05-08 22:48:11');

执行结果:
在这里插入图片描述

通过动态的SQL拼接这种方法可以帮助我们更好地处理动态列的数据,方便进行后续的数据分析和展示。这样就满足我们的场景了。

希望以上内容对您有帮助,欢迎点赞收藏,如有任何疑问或建议,请随时留言。感谢阅读!

相关推荐

  1. easyexcel 动态导出

    2024-05-11 10:56:06       44 阅读
  2. oracle 行转转行

    2024-05-11 10:56:06       33 阅读
  3. mysql

    2024-05-11 10:56:06       43 阅读
  4. WPF DataGrid 动态增加

    2024-05-11 10:56:06       58 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-11 10:56:06       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-11 10:56:06       106 阅读
  3. 在Django里面运行非项目文件

    2024-05-11 10:56:06       87 阅读
  4. Python语言-面向对象

    2024-05-11 10:56:06       96 阅读

热门阅读

  1. linux phpstudy 重启命令

    2024-05-11 10:56:06       36 阅读
  2. SSH简介:安全远程访问的基石

    2024-05-11 10:56:06       33 阅读
  3. Jtti:哪些方法可以降低美国CN2服务器的延迟?

    2024-05-11 10:56:06       30 阅读
  4. Hive优化(3)——索引优化

    2024-05-11 10:56:06       35 阅读
  5. 2024年记录

    2024-05-11 10:56:06       34 阅读
  6. sql分页查询

    2024-05-11 10:56:06       34 阅读
  7. pytorch 梯度更新过程

    2024-05-11 10:56:06       28 阅读
  8. PyTorch与深度学习:从入门到精通

    2024-05-11 10:56:06       32 阅读
  9. pytorch2ONNX时,AdaptiveAvgPool2d的相关问题

    2024-05-11 10:56:06       23 阅读
  10. 【python】Flask开发感悟

    2024-05-11 10:56:06       24 阅读
  11. 【软考】scrum的步骤

    2024-05-11 10:56:06       31 阅读
  12. 【C++】每日一题 103 二叉树的锯齿形层序遍历

    2024-05-11 10:56:06       34 阅读