妙用Update Select

2023-10-30

最常用的update语法是:
UPDATE <table_name>
SET <column_name1> = <value>, SET <column_name2> = <value>

如果我的更新值Value是从一条select语句拿出来,而且有很多列的话,用这种语法就很麻烦
第一,要select出来放在临时变量上,有很多个哦
第二,再将变量进行赋值。
列多起来非常麻烦,能不能像Insert那样,把整个Select语句的结果进行插入呢?就好象下面
insert into table1
(c1, c2, c3)
(select v1, v2, v3 from table2)

答案是可以的,具体的语法如下:
UPDATE <table_name> <alias>
SET (<column_name>,<column_name> ) = (
SELECT (<column_name>, <column_name>)
FROM <table_name>
WHERE <alias.column_name> = <alias.column_name>)
WHERE <column_name> <condition> <value>;

 

下面是这样一个例子:

两个表a、b,想使b中的memo字段值等于a表中对应id的name值
表a:id, name 
1 王
2 李
3 张
表b:id,ClientName   
            1 


(MS SQL Server)语句:update b   set   ClientName    = a.name    from a,b    where a.id = b.id  

(Oralce)语句:update b   set   (ClientName)    =   (SELECT name FROM a WHERE b.id = a.id)

update set from 语句格式

当where和set都需要关联一个表进行查询时,整个update执行时,就需要对被关联的表进行两次扫描,显然效率比较低。
对于这种情况,Sybase和SQL SERVER的解决办法是使用UPDATE...SET...FROM...WHERE...的语法,实际上就是从源表获取更新数据。

在 SQL 中,表连接(left join、right join、inner join 等)常常用于 select 语句,其实在 SQL 语法中,这些连接也是可以用于 update 和 delete 语句的,在这些语句中使用 join 还常常得到事半功倍的效果。

Update T_OrderForm SET T_OrderForm.SellerID =B.L_TUserID
FROM T_OrderForm A LEFT JOIN T_ProductInfo   B ON B.L_ID=A.ProductID

用来同步两个表的数据!

Oralce和DB2都支持的语法:

UPDATE A SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)

MS SQL Server不支持这样的语法,相对应的写法为:
UPDATE A  SET A1 = B1, A2 = B2, A3 = B3  FROM A LEFT JOIN B ON A.ID = B.ID

个人感觉MS SQL Server的Update语法功能更为强大。MS SQL SERVER的写法:
UPDATE A SET A1 = B1, A2 = B2, A3 = B3 FROM A, B WHERE A.ID = B.ID

在Oracle和DB2中的写法就比较麻烦了,如下:

UPDATE A SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
WHERE ID IN (SELECT B.ID FROM B WHERE A.ID = B.ID)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

妙用Update Select 的相关文章

随机推荐

  • springboot打包成war并部署到阿里云tomcat服务器最简洁有用的教程

    一 打包成war 1 配置文件pom xml中的
  • Visual C++ 2008 runtime files are out of data

    今天用 Setup Factory打了一个包 在win7系统上双击安装该包时 弹出如下错误 费了好长时间 最后才知道原因 是我将vcredist x86 exe作为从属文件加入Setup Factory时 Setup Factory对操作系
  • BGA焊盘设计的一般规则

    BGA焊盘设计的一般规则 1 焊盘直径既能影响焊点的可靠性又能影响元件的布线 焊盘直径通常小于焊球直径 为了获得可靠的附着力 一般减少20 25 焊盘越大 两焊盘之间的布线空间越小 如1 27mm间距的BGA封装 采用0 63mm直径焊盘
  • three.js几何体的_UV_、法向属性以及BufferGeometry类介绍

    一 几何体的 UV 以及法向属性 UV属性是一组二维坐标 每个顶点都有一个对应的UV坐标 在三维模型上贴上二维的纹理贴图时 需要将所有顶点映射到纹理上的对应位置 UV属性的取值范围一般是 0 1 表示纹理上的相对位置 通过修改UV属性 可以
  • Mybatis-plus全局配置主键生成策略

    mybatis可以配置全局的主键生成策略 也可以通过bean的属性加注解的方式设置 主键上使用 TableId注解 注解的type属性有6种选值 对应6中主键生成策略 当然还可以在数据库中设置该表字段的生成策略 mybatis plus默认
  • 微电子系统封装期末总结—国科大集成电路学院

    国科大集成电路学院曹立强老师开设的微电子系统封装课程 是集成电路工程专业研究生的学科基础课 通过讲述微电子电路的封装设计 制造 以及与封装技术密切相关的设备和材料基本概念与知识 要求学生掌握包括电子封装设计原理 准则 基本制造原理和工艺流程
  • 史上最通俗易懂的手写人工神经网络——(一)

    1 神经元 思维的基本单元 我们知道一方面计算机以速度飞快而称奇 但是对于事物识别以及复杂的任务却无能为力 另一方面人类没有计算机快 但是可以做很多极其复杂的事情 一只苍蝇有10万个左右的神经元就可以完成飞行 寻找食物 躲避天敌等等很复杂的
  • 数据结构-二叉排序树(图文详细版)

    文章目录 前言 一 二分搜索树的特性 1 中序遍历的序列是递增的序列 2 中序遍历的下一个节点 称后继节点 即比当前节点大的最小节点 3 中序遍历的前一个节点 称前驱节点 即比当前节点小的最大节点 二 添加节点 1 思路 2 代码实现 三
  • 计算方法(五):数值微分与数值积分

    文章目录 数值微分与数值积分 数值微分 利用插值多项式构造数值微分公式 等距结点处的数值微分公式 利用三次样条插值函数构造数值微分公式 构造数值积分公式的基本方法与有关概念 构造数值积分公式的基本方法 数值积分公式的余项 数值积分公式的代数
  • 织梦dedecms模板乱码解决方法

    出现模板乱码这种问题大多数是因此dedecms模板编码问题导致的乱码 解决办法我们可以使用一些相关软件打开 然后设置页面编码即可了 DEdecms有gbk和utf 8两个版本的哦 乱码是因为字符编码不一致造成的 出现的原因有以下几种 一 你
  • 面试题:computed与watch的区别(转载)

    一 computed computed看上去是方法 但是实际上是计算属性 它会根据你所依赖的数据动态显示新的计算结果 计算结果会被缓存 computed的值在getter执行后是会缓存的 只有在它依赖的属性值改变之后 下一次获取comput
  • 关于修改ubuntu20.04分辨率的问题

    默认情况下 setting下的dsiplay是无法修改分辨率的 下面开始设置 第一步 添加分辨率 用于后面的配置文件参数修改 cvt 1920 1080 第二步 查看已经支持的分辨率 xrandr 第三步 修改配置文件 输入 sudo ge
  • 解决Python:'gbk' codec can't decode byte 0xae in position 199: illegal multibyte sequence

    我在读取txt文件中报了一个 gbk codec can t decode byte 0xae in position 199 illegal multibyte sequence 解决方法 加上一个 encoding ISO 8859 1
  • AI指数报告:让我们从18个分立的视角来看AI

    AI指数报告 让我们从18个分立的视角来看AI 最近 斯坦福 人工智能百年 AI100 专家小组 非盈利性项目AI Index 发起了一项AI指数报告 追踪学术界 产业界 开源软件和公共兴趣范畴的18个分立的视角评估人工智能活跃度 盘点计算
  • DVWA stored 初级

    这里name被限制长路了 是10 不影响 在message输入 在name随便输入 弹窗1 过
  • 【数模】拟合算法

    拟合算法的介绍 拟合和插值问题的对比 回顾 数模 插值算法 不同 插值算法 得到的多项式f x 要经过所有样本点 但若样本点太多 则该多项式次数过高 就会造成龙格现象 拟合问题 不用曲线一定经过给定的点 尽管分段可避免龙格现象 但多数情况更
  • python实现验证码识别

    前言 大家在做自动化的过程中 应该遇到过登录 需要输入验证码的场景 一般的话 解决方案就是 需要后台的开发同学提供万能验证码 这样每次都麻烦开发也不是很好 所以 还是自己搞一下把 一 图片识别 验证码识别 选择使用ddddocr这个开源库
  • Python爬虫:抓取多级页面数据

    前面讲解的爬虫案例都是单级页面数据抓取 但有些时候 只抓取一个单级页面是无法完成数据提取的 本节讲解如何使用爬虫抓取多级页面的数据 在爬虫的过程中 多级页面抓取是经常遇见的 下面以抓取二级页面为例 对每级页面的作用进行说明 一级页面提供了获
  • java 反射将字符串转换为对应的类型

    做反射的时候可能会有这种需求 给定一个字符串和一个类型 将字符串转换为指定的类型 public class TypeUtils public static Object stringToNullableTarget String strin
  • 妙用Update Select

    最常用的update语法是 UPDATE