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

admin2年前 (2024-06-05)基础运维知识376
点击下载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授权怎么用-mysql教程

MySQL 授权指南 授权是什么? 授权是指授予其他用户访问和操作 MySQL 数据库的权限。 如何授权? 使用 MySQL 的 GRANT 语句可以授予授权。语法如下: GRANT ON TO...

sql分页查询语句怎么写-SQL

SQL 分页查询语句详解 分页查询是数据查询中常用的操作,它可以将查询结果分成多个页面,方便用户查看和操作。SQL 中分页查询的实现需要用到 LIMIT 和 OFFSET 子句。 语法: SELEC...

mysql怎么停止服务-mysql教程

如何在 MySQL 中停止服务 要停止 MySQL 服务,请按照以下步骤操作: 方法 1:使用 MySQL 命令行客户端 打开命令行终端。 连接到 MySQL 服务器: <a style=...

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

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

mysql怎么使用gtid-mysql教程

如何使用 MySQL 的 GTID GTID 是什么? 全球事务标识符 (GTID) 是一种机制,用于识别和跟踪 MySQL 事务在复制组中的执行顺序。GTID 解决了复制过程中数据不一致的问题,确...

mysql dba是什么意思-mysql教程

MySQL DBA(数据库管理员)的职责 MySQL DBA 负责管理和维护 MySQL 数据库,以确保其高效稳定地运行。其职责包括: 基础架构管理 安装、配置和部署 MySQL 数据库 管理数据...

发表评论

访客

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