mysql数据库与表的基本操作总结(Mysql、Oracle中常用的多表修改语句总结)
类别:数据库 浏览量:1190
时间:2022-01-19 00:26:22 mysql数据库与表的基本操作总结
Mysql、Oracle中常用的多表修改语句总结今天在sql训练题库中看到了这题,这是一道很有代表性的多表修改题,其实解出这道题并不难,无论是mysql中还是oracle中都有很多种解法,接下来就好好归纳一下这些解法。
msyql中多表修改
对于mysql中常用的多表修改语句,还是用例子来解释一下吧。
|
//建表 create table aaa(id int ,value1 int (5),value2 int (5),value3 int (5),value4 int (5)); create table bbb like aaa; //插入数据 insert into aaa values (1,0,0,0,0),(2,0,0,0,0),(3,0,0,0,0),(4,0,0,0,0),(5,0,0,0,0),(6,0,0,0,0),(7,0,0,0,0); insert into bbb values (1,11,12,13,14),(3,31,32,33,34),(5,51,52,53,54); //备份 create table a1 select * from aaa; create table b1 select * from bbb; |
一般多表修改:(在mysql和Oracle中都适用,下面也会解释Oracle中的)
|
//一般多表修改 update a1 set a1.value1 = ( select b1.value1 from b1 where a1.id = b1.id), a1.value2 = ( select b1.value2 from b1 where a1.id = b1.id); |
表关联多表修改(这个只适用于mysql中)
|
//表关联多表修改 update a1 inner join b1 on a1.id = b1.id set a1.value1 = b1.value1, a1.value2 = b1.value2,a1.value3 = b1.value3; |
oracle中多表修改
|
--建表 create table aaa(id number,value1 number,value2 number,value3 number,value4 number); create table bbb(id number,value1 number,value2 number,value3 number,value4 number); --插入数据 insert into aaa values (1,0,0,0,0); insert into aaa values (2,0,0,0,0); insert into aaa values (3,0,0,0,0); insert into aaa values (4,0,0,0,0); insert into aaa values (5,0,0,0,0); insert into aaa values (6,0,0,0,0); insert into aaa values (7,0,0,0,0); insert into bbb values (1,11,12,13,14); insert into bbb values (3,31,32,33,34); insert into bbb values (5,51,52,53,54); -- 备份 create table a1 as select * from aaa; create table b1 as select * from bbb; |
一般多表修改:
和上面mysql中语句一样,这个写法比较容易理解,但是效率实在有些不尽人意,如果你们的多表修改只用修改一列(像最上面的那题一样),用这种写法挺好的。
|
//一般多表修改 update a1 set a1.value1 = ( select b1.value1 from b1 where a1.id = b1.id), a1.value2 = ( select b1.value2 from b1 where a1.id = b1.id); |
但是涉及到了多列修改,用这个就不太现实了,在oracle中就提供了一种语法让我们去进行多表修改和新增。
Merge into
merge into是update和insert语句的结合,可以同时实现update和insert的功能,在这里我就不多解释了,简单介绍一下merge into的语法吧。
|
merge into 目标表a ---into指向的目标表就是我们要做更新操作的表。 using 源表b ---using指向的表不能被更改,它还可以是视图、结果集等。 on (a.id = b.id) ---on()里面是用作目标表和源表匹配的条件,条件满足则匹配成功。 when matched then ---when matched then 后面接的是修改语句。 update set ... when not matched then ---when not matched then 后面接的是新增语句。 insert values (....); |
|
merge into a1 using b1 on (a1.id = b1.id) when matched then update set a1.value1 = b1.value1,a1.value2 = b1.value2,a1.value3 = b1.value3; |
exists多表修改
exists同样也适用于mysql和oracle,如果没有硬性要求表a根据表b的数据去修改,使用exists也是可以的。使用exists后的sql执行顺序是先执行外查询再执行内查询,所以多表修改就不能将表a1的值改为表a2的值。
|
update a1 set a1.value1 = 99,a1.value2 = 999,a1.vlaue3=999 where exists( select value1 from b1 where a1.id = b1.id); |
到此这篇关于Mysql、Oracle中常用的多表修改语句的文章就介绍到这了,更多相关Mysql、Oracle常用多表修改语句内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://blog.csdn.net/wankao/article/details/109454880
您可能感兴趣
- 如何看idea连接mysql数据库(IDEA 链接Mysql数据库并执行查询操作的完整代码)
- mysql 性能调优技巧(4 款 MySQL 调优工具,公司大神都在用!)
- 适合小白入门的mysql教程索引简介(一篇带给你MySQL高性能索引)
- mysql自增锁(深入剖析 MySQL 自增锁)
- mysql中group_concat
- mysql的三种模式(详解 MySQL的FreeList机制)
- mysql有哪些索引和聚簇索引(MySQL 独立索引和联合索引的选择)
- mysql乐观锁与mvcc(MySQL中的乐观锁,悲观锁和MVCC全面解析)
- MySQL SQL Assistant智能提示
- mysqlupdate原理(MySQL UPDATE 语句的非标准实现代码)
- mysql索引为什么是b+树(mysql 使用B+树索引有哪些优势)
- mysql完整整理(Mysql隔离性之Read View的用法说明)
- mysql账户访问权限(MySQL 权限控制详解)
- mysql自定义函数怎么设置(MySQL自定义变量?学不废不收费~)
- mysql哪个版本可以下载msi(新手必备之MySQL msi版本下载安装图文详细教程)
- mysql写入效率越来越差(MYSQL大量写入问题优化详解)
- 美国数十万加仑牛奶倒进下水道,世界会重演1929年的大萧条吗(美国数十万加仑牛奶倒进下水道)
- 美国数十万加仑牛奶倒入下水道,贫民区食不果腹,历史再次重演(美国数十万加仑牛奶倒入下水道)
- 美国倒掉数十万加仑牛奶 上热搜第一,这一幕似曾相识(美国倒掉数十万加仑牛奶)
- 深度 倒牛奶 这一幕为何又在美国上演(深度倒牛奶)
- 美国数十万加仑牛奶倒下水道怎么回事 原因曝光令人心痛(美国数十万加仑牛奶倒下水道怎么回事)
- 探索中国神秘文字(探索中国神秘文字)
热门推荐
- 云主机越来越受欢迎吗(云主机的发展前景怎样?会成为主流吗?)
- html锚点定位
- python 二叉树的深度遍历(python 将有序数组转换为二叉树的方法)
- vue3.0怎么往标签填数据(Vue3.0写自定义指令的简单步骤记录)
- 详解DB2 sqlstate 57016 SQLCODE=-668 原因码 "7"错误的快速解决办法(详解DB2 sqlstate 57016 SQLCODE=-668 原因码 "7"错误的快速解决办法)
- phpstudy使用教程最新版(phpstudy安装使用图文教程)
- python中lambda教程(浅析python的Lambda表达式)
- CSS边框border样式缩写
- php解压压缩包(PHP 实现文件压缩解压操作的方法)
- laravel框架两表联查(Laravel 使用查询构造器配合原生sql语句查询的例子)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9