SQL脚本把多行SQL数据变成一条多列数据

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【5月更文挑战第4天】

》》》》》魏红斌带你学sql脚本《《《《《


更多sql脚本学习点击个人主页

作为技术开发者,本月我们的核心焦点在于深入探索SQL脚本的编写与应用,这一关键技术使得我们能够高效地查询与操作数据库中的信息。通过精心编写的SQL指令,我们能够灵活地检索所需数据,同时也支持对数据库进行插入、更新、删除等写操作。尤为值得一提的是,这些脚本的封装与复用特性,意味着一旦开发完成,它们可以迅速适应不同场景,仅需调整相应参数即可在新环境中部署运行,极大地提升了开发效率与代码的可维护性。

考虑到实际开发环境中MySQL安装配置的多样性和复杂性,我们巧妙利用了阿里云的RDS MySQL版服务,它为我们提供了一个稳定、高效的云端数据库解决方案。无需费心于本地环境搭建,只需几个简单的步骤,即可接入功能完备的云数据库:

对于初次接触云服务的开发者:

  1. 访问选购平台:第一步,直接访问阿里云数据库网站,这里是获取云数据库服务的起点。
  2. 选购与购买:在丰富的配置选项中,根据项目需求选择合适的RDS套餐,完成在线支付流程。这一过程如同在线购物一样直观便捷。
  3. 控制台操作:购买成功后,你将自动进入RDS控制台,这里是你的数据库管理中枢。你可以执行包括数据库创建、用户管理在内的所有必要操作。

已有阿里云数据库的用户:

  • 访问实例:直接跳转至RDS实例列表,根据地域筛选并点击目标实例ID。
  • 数据库与账号管理:在左侧菜单,先“创建数据库”以准备数据存储空间,随后在“账号管理”中创建访问账号,确保安全地操控数据库。
  • 登录使用:创建账号后,利用提供的DMS工具登录。输入账号凭证,成功登录后,通过双击数据库名称即可开始使用,执行SQL语句并实时查看执行结果。

无论是从零开始还是在现有基础上拓展,阿里云RDS MySQL版都为我们提供了一条快速、安全且高效的路径,使我们能够专注于SQL脚本的开发与优化,而非基础架构的繁琐配置。

  • 推荐:同时还要提一下阿里云自研的PolarDB国产化数据库,100%兼容MySQL和PostgreSQL生态,支持分布式扩展,高度兼容Oracle语法。也是咱们的国货之光,希望同学们了解支持:阿里云polardb国产数据
  • 编写SQL脚本

在DMS界面的SQL编辑器区域,你可以开始编写SQL脚本。无论是查询(SELECT)、插入(INSERT)、更新(UPDATE)、删除(DELETE)还是创建表(CREATE TABLE)等操作,都可以在这里直接输入。

  • 执行SQL脚本

编写好SQL脚本后,点击“执行”或者相应的运行按钮(通常是一个向右的箭头图标),系统将会执行你的SQL命令,并在下方的结果区域显示执行结果。如果脚本有错误,错误信息也会在此处展示,帮助你调试修正。

  • 查看执行结果

执行成功的SQL语句会返回查询结果或一个确认信息,比如“受影响的行数”对于INSERT、UPDATE、DELETE操作,或是查询结果集对于SELECT操作。

sql脚本:

接下来我们要解析的是这个sql脚本脚本执行过程如下:

SELECT 
 id,
 name,
 SUM(CASE WHEN quarter=1 THEN number ELSE 0 END) '一季度',
 SUM(CASE WHEN quarter=2 THEN number ELSE 0 END) '二季度',
 SUM(CASE WHEN quarter=3 THEN number ELSE 0 END) '三季度',
 SUM(CASE WHEN quarter=4 THEN number ELSE 0 END) '四季度'
FROM test
GROUP BY id,name
  1. SELECT 部分选择了需要显示的列:id, name,以及四个计算列,分别代表了一至四季的数量总和。计算列使用了SUM(CASE WHEN...END)结构,这是一种条件聚合函数,用于根据quarter的值累加number
  2. CASE WHEN 语句用于条件判断,例如 CASE WHEN quarter=1 THEN number ELSE 0 END 表示:如果记录的季度(quarter)为1(即一季度),则取该记录的number值,否则取0。这样可以确保在计算每个季度总和时,只有属于该季度的数据被计入。
  3. FROM 指定了查询的表名为test
  4. GROUP BY 部分按照idname进行分组,意味着结果将展示每一对唯一idname组合下的季度数量统计。
  5. 最终输出的结果格式会是每一行包含idname以及四个季度的数量总和。

由于我无法直接执行数据库查询或访问实际数据,我无法直接提供具体的结果输出。但是,如果你在拥有该test表的数据库环境中运行此脚本,你将会得到一个列表,列表中的每一行展示了一个唯一的idname组合,以及它们在一至四季的number总和。例如:

1id | name  | 一季度 | 二季度 | 三季度 | 四季度
2------------------------------------------
31  | item1 | 120    | 150    | 80     | 200
42  | item2 | 90     | 130    | 110    | 170
5...

这里每一行展示了不同idname下,各个季度的number总和。请注意,这些数字是假设的例子,实际结果取决于test表中的数据内容。

附:~~~~~

如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!

入口:新老同学免费试用

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
简介:本文整理自阿里云高级技术专家李麟在Flink Forward Asia 2025新加坡站的分享,介绍了Flink 2.1 SQL在实时数据处理与AI融合方面的关键进展,包括AI函数集成、Join优化及未来发展方向,助力构建高效实时AI管道。
523 43
|
2月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
本文整理自阿里云的高级技术专家、Apache Flink PMC 成员李麟老师在 Flink Forward Asia 2025 新加坡[1]站 —— 实时 AI 专场中的分享。将带来关于 Flink 2.1 版本中 SQL 在实时数据处理和 AI 方面进展的话题。
173 0
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
|
3月前
|
SQL
SQL如何只让特定列中只显示一行数据
SQL如何只让特定列中只显示一行数据
|
7月前
|
SQL 自然语言处理 数据库
【Azure Developer】分享两段Python代码处理表格(CSV格式)数据 : 根据每列的内容生成SQL语句
本文介绍了使用Python Pandas处理数据收集任务中格式不统一的问题。针对两种情况:服务名对应多人拥有状态(1/0表示),以及服务名与人名重复列的情况,分别采用双层for循环和字典数据结构实现数据转换,最终生成Name对应的Services列表(逗号分隔)。此方法高效解决大量数据的人工处理难题,减少错误并提升效率。文中附带代码示例及执行结果截图,便于理解和实践。
165 5
|
3月前
|
SQL
SQL中如何删除指定查询出来的数据
SQL中如何删除指定查询出来的数据
|
3月前
|
SQL 关系型数据库 MySQL
SQL如何对不同表的数据进行更新
本文介绍了如何将表A的Col1数据更新到表B的Col1中,分别提供了Microsoft SQL和MySQL的实现方法,并探讨了多表合并后更新的优化方式,如使用MERGE语句提升效率。适用于数据库数据同步与批量更新场景。
|
4月前
|
SQL DataWorks 数据管理
SQL血缘分析实战!数据人必会的3大救命场景
1. 开源工具:Apache Atlas(元数据管理)、Spline(血缘追踪) 2. 企业级方案:阿里DataWorks血缘分析、腾讯云CDW血缘引擎 3. 自研技巧:在ETL脚本中植入版本水印,用注释记录业务逻辑变更 📌 重点总结:
|
5月前
|
SQL 数据挖掘 关系型数据库
【SQL 周周练】一千条数据需要做一天,怎么用 SQL 处理电表数据(如何动态构造自然月)
题目来自于某位发帖人在某 Excel 论坛的求助,他需要将电表缴费数据按照缴费区间拆开后再按月份汇总。当时用手工处理数据,自称一千条数据就需要处理一天。我将这个问题转化为 SQL 题目。
173 12
|
5月前
|
SQL 数据采集 资源调度
【SQL 周周练】爬取短视频发现数据缺失,如何用 SQL 填充
爬虫爬取抖音和快手的短视频数据时,如果遇到数据缺失的情况,如何使用 SQL 语句完成数据的补全。
125 5
|
7月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法

热门文章

最新文章