mysql中怎么实现列转行-mysql教程

admin2年前 (2024-06-05)基础运维知识420
点击下载TXT

MySQL 中实现列转行的两种方法

在 MySQL 中,将列转行为行的操作通常称为 "解旋"。有两种常见的方法可以实现这一操作:

方法一:UNPIVOT 运算符

UNPIVOT 运算符用于将多列数据转换为单列数据,每一行包含一个列名和一个值。语法如下:

SELECT col1, val
FROM table_name
UNPIVOT (val FOR col IN (col2, col3, ..., coln))
登录后复制

例如,以下查询将表 sales 中的 product_id、product_name、sales_amount、sales_date 四列解旋为两列:

SELECT product_id, val
FROM sales
UNPIVOT (val FOR col IN (product_name, sales_amount, sales_date))
登录后复制

方法二:CASE 表达式

CASE 表达式也可以用于将列转行为,通过将每个列值作为 CASE 语句中的一个分支。语法如下:

SELECT
  CASE 
    WHEN col1 = 'value1' THEN val1
    WHEN col1 = 'value2' THEN val2
    ...
    ELSE NULL
  END AS new_column,
  col2,
  col3,
  ...
FROM table_name
登录后复制

例如,以下查询将表 sales 中的 product_id、product_name、sales_amount 三列解旋为 product 和 value 两列:

SELECT
  CASE 
    WHEN product_name IS NOT NULL THEN product_name
    WHEN sales_amount IS NOT NULL THEN sales_amount
    ELSE NULL
  END AS product,
  product_id,
  sales_amount
FROM sales
登录后复制

相关文章

mysql 42000到底怎么解决-mysql教程

如何解决 MySQL 错误 42000 MySQL 错误 42000 通常是由锁等待造成的。当一个线程尝试获取另一个线程已持有的锁时,就会发生这种情况。 解决方法: 1. 确定导致锁等待的查询 使...

sql游标怎么排序-SQL

SQL 游标排序 SQL 游标是一种允许程序逐行访问查询结果集的机制。但是,默认情况下,游标不会对结果进行排序。 如何对 SQL 游标进行排序? 要对 SQL 游标进行排序,可以使用 ORDER B...

mysql定时备份怎么设置-mysql教程

MySQL 定时备份设置指南 第一步:创建备份脚本 <a style="color:#f60; text-decoration:underline;" href="...

sql分离数据库怎么操作-SQL

SQL 分离数据库的操作步骤 步骤 1:导出源数据库 使用 mysqldump 命令导出源数据库。 mysqldump -u username -p password databasename &...

mysql停止服务怎么打开-mysql教程

如何重启 MySQL 服务 1. 确认 MySQL 服务已停止 通过命令 sudo systemctl status mysql 检查服务状态。 2. 启动 MySQL 服务 使用命令 sudo s...

mysql怎么卸载干净重装-mysql教程

如何干净卸载并重新安装 MySQL 步骤 1:卸载 MySQL 停止 MySQL 服务: sudo service <a style="color:#f60; text-deco...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。