假设我有以下语句,并且内部连接会在3行中导出a.Id = b.Id,但是3行中的每一行都有不同的b.Value.由于tableA中只有一行正在更新,更新中会使用哪三个值?
- UPDATE a
- SET a.Value = b.Value
- FROM tableA AS a
- INNER JOIN tableB as b
- ON a.Id = b.Id
解决方法
我不认为这种情况有规则,你不能依赖于一个特定的结果.
如果你是一个特定的行,说最新的一个,你可以使用apply,如:
- UPDATE a
- SET a.Value = b.Value
- FROM tableA AS a
- CROSS APPLY
- (
- select top 1 *
- from tableB as b
- where b.id = a.id
- order by
- DateColumn desc
- ) as b