》》》》》魏红斌带你学sql脚本《《《《《
更多sql脚本学习点击个人主页
作为技术开发者,本月我们的核心焦点在于深入探索SQL脚本的编写与应用,这一关键技术使得我们能够高效地查询与操作数据库中的信息。通过精心编写的SQL指令,我们能够灵活地检索所需数据,同时也支持对数据库进行插入、更新、删除等写操作。尤为值得一提的是,这些脚本的封装与复用特性,意味着一旦开发完成,它们可以迅速适应不同场景,仅需调整相应参数即可在新环境中部署运行,极大地提升了开发效率与代码的可维护性。
考虑到实际开发环境中MySQL安装配置的多样性和复杂性,我们巧妙利用了阿里云的RDS MySQL版服务,它为我们提供了一个稳定、高效的云端数据库解决方案。无需费心于本地环境搭建,只需几个简单的步骤,即可接入功能完备的云数据库:
对于初次接触云服务的开发者:
- 访问选购平台:第一步,直接访问阿里云数据库网站,这里是获取云数据库服务的起点。
- 选购与购买:在丰富的配置选项中,根据项目需求选择合适的RDS套餐,完成在线支付流程。这一过程如同在线购物一样直观便捷。
- 控制台操作:购买成功后,你将自动进入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;
解析:此脚本意在更新Table1
中c
列的值,当且仅当该列值为NULL
。更新的值是从Table2
中选取的,选取的依据是两表中a
列的值相等。换句话说,这个查询会查找所有Table1
中c
为NULL
的行,并将其c
列的值替换为与之相对应的(根据a
列匹配)Table2
中的c
值。
可能的输出结果:
由于UPDATE
操作不直接返回结果集,所以执行后不会直接看到输出,但可以理解为执行后,Table1
中所有原本c
为NULL
的行,如果能在Table2
找到匹配的a
值,则其c
列会被相应地更新。
方法2:
Sql
1UPDATE A 2SET newqiantity = B.qiantity 3FROM A, B 4WHERE A.bnum = B.bnum;
解析:这个脚本使用了老式的FROM子句连接语法来更新表A
的newqiantity
列,更新的值取自表B
的qiantity
列,条件是两个表的bnum
列相等。这是一种更新连接表中数据的方法,确保只有那些在A
和B
表中bnum
匹配的记录会被更新。
可能的输出结果:
同样,此操作不直接产生可视输出,但执行后,表A
中所有与表B
中bnum
匹配的行,其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服务器免费试用参与!
入口:新老同学免费试用