SQLite 更新查询 – 带有别名的子查询不起作用

本教程将介绍SQLite 更新查询 - 带有别名的子查询不起作用的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

SQLite 更新查询 - 带有别名的子查询不起作用 教程 第1张

问题描述

我需要更新一个 SQLite 表.

表格如下:

ID| Address| CallNumber|  RefID
-----+--------------------+-------------------------------------------
ef78 | library| 2002/13| 100002
no56 | Lit | 0189| 100003
rs90 | temp|  | 100003

对于 Address = "Lit" 的每一列,都有一个 Address = 'temp' 的列具有相同的 RefID.现在我需要使用具有相同 RefID 的列中的值CallNumber"更新每个 Address = temp".

更新后的表格应如下所示:

ID| Address| CallNumber|  RefID
-----+--------------------+-------------------------------------------
ef78 | library| 2002/13| 100002
no56 | Lit | 0189| 100003
rs90 | 0189|  | 100003

我试过了:

UPDATE Location
SET address = foo.callnumber
FROM (select RefID, CallNumber FROM Location) foo
WHERE foo.RefID=Location.RefID AND Location.Address = 'temp';

但我得到的只是来自"附近的语法错误.

有什么线索吗?

推荐答案

UPDATE 命令 没有FROM 子句.

使用相关子查询:

UPDATE Location
SET Address = (SELECT CallNumber
FROM Location L2
WHERE L2.RefID = Location.RefID
  AND L2.Address = 'Lit')
WHERE Address = 'temp'

好了关于SQLite 更新查询 - 带有别名的子查询不起作用的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。