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

use*_*165 5 sqlite alias subquery

我需要更新一个SQLite表.

该表看起来像:

ID   | Address            | CallNumber   |  RefID
-----+--------------------+-------------------------------------------
ef78 | library            | 2002/13      | 100002
no56 | Lit                | 0189         | 100003
rs90 | temp               |              | 100003
Run Code Online (Sandbox Code Playgroud)

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

更新的表应如下所示:

ID   | Address            | CallNumber   |  RefID
-----+--------------------+-------------------------------------------
ef78 | library            | 2002/13      | 100002
no56 | Lit                | 0189         | 100003
rs90 | 0189               |              | 100003
Run Code Online (Sandbox Code Playgroud)

我试过这个:

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

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

任何线索?

CL.*_*CL. 13

UPDATE命令没有FROM子句.

使用相关子查询:

UPDATE Location
SET Address = (SELECT CallNumber
               FROM Location L2
               WHERE L2.RefID = Location.RefID
                 AND L2.Address = 'Lit')
WHERE Address = 'temp'
Run Code Online (Sandbox Code Playgroud)

  • @PiniCheyni然后你必须决定避免多个子查询是否比解决你的实际问题更重要. (3认同)