SQL SERVER Update from 使用陷阱

原创 2017年01月03日 14:45:05

update A set from A left join B on
此方法常用来使用根据一个表更新另一个表的数据,来进行数据同步更新。若是A表行与B表行为一对一的对应关系,更新不存在问题,若是A表行与B表行对应关系为一对多的时候,需注意A表更新的列并非B表的累计值,而是第一个数值。

首先建立两个表 A,B 对A表建立触发器查看更新信息

CREATE TABLE yshA (
keyA VARCHAR(10),
value INT
)

CREATE TABLE yshB (
keyB VARCHAR(10),
valueB INT
)

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

CREATE TRIGGER trg_YSHA_Up
   ON  YSHA
   AFTER UPDATE
AS 
BEGIN
    SET NOCOUNT ON;
    DECLARE @now VARCHAR(60)
    SET @now=convert(varchar,GETDATE())
    SELECT *,'i',@now FROM inserted
    SELECT *,'d',@now FROM deleted

END
GO

1、对数据进行更新

  • 对表数据进行初始化A
INSERT INTO yshA VALUES (1,0)
INSERT INTO yshB VALUES (1,1)
INSERT INTO yshB VALUES (1,2)

SELECT * FROM  yshA A LEFT JOIN yshB B ON keyA=keyB

执行结果
这里写图片描述

UPDATE A SET value = value + valueB FROM yshA A LEFT JOIN yshB B ON keyA=keyB

SELECT * FROM yshA

此执行结果理论上 value 应为3 ,实际执行 value 结果为1

这里写图片描述

  • 对表数据进行初始化B
DELETE FROM yshA
DELETE FROM yshB
INSERT INTO yshA VALUES (1,0)
INSERT INTO yshB VALUES (1,2)
INSERT INTO yshB VALUES (1,1)


UPDATE A SET value = value + valueB FROM yshA A LEFT JOIN yshB B ON keyA=keyB

SELECT * FROM yshA

此方式实际执行 value 结果为2

2、 原因分析

理论上以上两种更新的结果应为一致,同样的数据 方法B更新的结果与 方法A更新的结果不一致。针对此问题进行分析,首先进行执行计划分析,查看其它的正常,但是left join 之后多了一步执行操作 Top 开销 因此可以解析为什么两次更新的结果不一致,因为只根据首条关联进行更新。
这里写图片描述

关于update set from where

关于update set from where   下面是这样一个例子: 两个表a、b,想使b中的memo字段值等于a表中对应id的name值      表a:id,na...
  • xcbsdu
  • xcbsdu
  • 2011年08月31日 16:54
  • 98507

关于update set from where

关于update set from where   下面是这样一个例子: 两个表a、b,想使b中的memo字段值等于a表中对应id的name值      表a:id,name...
  • zengmingen
  • zengmingen
  • 2016年03月10日 15:17
  • 1898

Oracle没有UPDATE FROM 的解决方法

Oracle没有update from语法,可以通过两种写法实现同样的功能: 1:子查询UPDATE A SET A.NAME=(SELECT B.NAME FROM B WHERE B.ID=A.I...
  • jarniyy
  • jarniyy
  • 2016年02月29日 23:19
  • 927

mysql下使用update set from select

最近遇到很多数据结构的需求是这样的: 先select出来 然后在update 一下  条件不变 写一条语句搞定: UPDATE tab_game_version  as a IN...
  • u010089432
  • u010089432
  • 2017年05月10日 09:52
  • 3072

update from 语句的写法

UPDATE EPD_ITEM_MASTER rrSET plan_price =(SELECT top 1 plan_price FROM newdata WHERE item_code = rr....
  • precipitant
  • precipitant
  • 2006年01月17日 08:40
  • 2676

select from update row的实现

DTCC大会上,阿里江疑的演讲中提到一个:select from update hot row;不明白如何在Oracle中实现的,他的意思是在一条SQL中实现update和select这条update...
  • bisal
  • bisal
  • 2015年04月19日 21:42
  • 2094

sql语句 update from

sql server提供了update的from 子句,可以将要更新的表与其它的数据源连接起来。虽然只能对一个表进行更新,但是通过将要更新的表与其它的数据源连接起来,就可以在update的表达式 中引...
  • yuexuning58
  • yuexuning58
  • 2012年05月07日 16:25
  • 11576

Oracle中的三种 UPDATE FROM 的解决方案

表的更新操作中,在很多情况下需要在表达式中引用要更新的表以外的数据。象sql server提供了update的from 子句,可以将要更新的表与其它的数据源连接起来。虽然只能对一个表进行更新,但是通过...
  • wzy0623
  • wzy0623
  • 2016年12月29日 14:00
  • 2473

mysql update from 关联更新 从一个表字段 到另外一个表字段

mssql 子查询更新 update log set uin= b.uin from log a,logs b where a.accountuin = b.accountuin my...
  • jsbba
  • jsbba
  • 2013年11月21日 20:50
  • 9687

sql update set from 的用法 (转)

转:http://www.cnblogs.com/zhang9418hn/archive/2012/03/21/2409551.html   关键字: update set from  下面...
  • foart
  • foart
  • 2012年09月29日 11:58
  • 13761
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQL SERVER Update from 使用陷阱
举报原因:
原因补充:

(最多只允许输入30个字)