SQL脚本利用带关联子查询Update语句更新数据

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
全局流量管理 GTM,标准版 1个月
简介: 【5月更文挑战第5天】

》》》》》魏红斌带你学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脚本脚本执行过程如下:

方法1:
Update Table1
set c = (select c from Table2 where a = Table1.a)
where c is null 
方法2:
update  A
set  newqiantity=B.qiantity
from  A,B
where  A.bnum=B.bnum
方法3:
update
(select A.bnum ,A.newqiantity,B.qiantity from A
left join B on A.bnum=B.bnum) AS C
set C.newqiantity = C.qiantity
where C.bnum ='001'

这三个SQL语句都是用于更新表中某些列的值,基于不同的条件和数据来源。下面我将逐一解析这些脚本并简要说明它们的作用及可能的输出结果。

方法1:

Sql

1UPDATE Table1
2SET c = (SELECT c FROM Table2 WHERE a = Table1.a)
3WHERE c IS NULL;

解析:此脚本意在更新Table1c列的值,当且仅当该列值为NULL。更新的值是从Table2中选取的,选取的依据是两表中a列的值相等。换句话说,这个查询会查找所有Table1cNULL的行,并将其c列的值替换为与之相对应的(根据a列匹配)Table2中的c值。

可能的输出结果:

由于UPDATE操作不直接返回结果集,所以执行后不会直接看到输出,但可以理解为执行后,Table1中所有原本cNULL的行,如果能在Table2找到匹配的a值,则其c列会被相应地更新。

方法2:

Sql

1UPDATE A
2SET newqiantity = B.qiantity
3FROM A, B
4WHERE A.bnum = B.bnum;

解析:这个脚本使用了老式的FROM子句连接语法来更新表Anewqiantity列,更新的值取自表Bqiantity列,条件是两个表的bnum列相等。这是一种更新连接表中数据的方法,确保只有那些在AB表中bnum匹配的记录会被更新。

可能的输出结果:

同样,此操作不直接产生可视输出,但执行后,表A中所有与表Bbnum匹配的行,其newqiantity将被设置为对应B表行的qiantity值。

方法3:

Sql

1UPDATE
2(SELECT A.bnum, A.newqiantity, B.qiantity
3 FROM A
4 LEFT JOIN B ON A.bnum = B.bnum) AS C
5SET C.newqiantity = C.qiantity
6WHERE C.bnum = '001';

解析:这是一个更复杂的更新方式,首先通过一个子查询创建了一个名为C的临时结果集,该结果集包含了表A和表B通过bnum左连接后的数据。然后,它只更新这个临时结果集中bnum为'001'的行的newqiantity列,将其设置为对应qiantity的值。注意这里实际上可能不需要更新,因为更新的值和原来的值来自同一源(C.qiantity),除非在实际应用中有未提及的逻辑或后续处理步骤。

可能的输出结果:

执行后,如果存在bnum为'001'的行,理论上这行的newqiantity会被更新为其自身的qiantity值(尽管这种更新看起来多余)。但由于是基于特定条件C.bnum = '001',只有满足这一条件的行才会受到影响,而结果不会直接显示,而是体现在表A的数据变化上。

附:~~~~~

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

入口:新老同学免费试用

目录
相关文章
|
1月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
2月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
2月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
2月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
2月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
542 4
|
2月前
|
SQL 关系型数据库 PostgreSQL
遇到SQL 子查询性能很差?其实可以这样优化
遇到SQL 子查询性能很差?其实可以这样优化
156 2
|
1月前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
35 0
|
2月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
112 0
|
SQL
SQL UPDATE 语句
SQL UPDATE 语句
152 0
|
SQL 关系型数据库 MySQL