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)
| 归档时间: |
|
| 查看次数: |
5190 次 |
| 最近记录: |