1

我有 2 个 sqlite 数据库,我正在尝试将数据从一个数据库插入到另一个数据库。例如,“db-1.sqlite”有一个表 '1table' 有 2 列('name'、'state')。此外,“db-2.sqlite”有一个表 '2table' 有 2 列('name'、'url')。两个表都包含一个“名称”值列表,这些值彼此最常见但随机化,因此每行的 id 不匹配。

我想将“url”列的值插入到 db-1 的表中,但我想确保每个 url 值都指向其对应的“名称”值。

到目前为止,我已经这样做了:

> sqlite3 db-1.sqlite
sqlite> alter table 1table add column url;
sqlite> attach database 'db-2.sqlite' as db2;

现在,我不确定的部分:

sqlite> insert into 1table(url) select db2.2table.url from db2.2table where 1table.name==db2.2table.name

如果你看看我上面写的,你可以知道我想要完成什么,但这是不正确的。如果我能在这件事上得到任何帮助,我将不胜感激!!

4

1 回答 1

5

SQL 中的相等比较运算符是=,不是==

另外,我怀疑您应该更新 1table,而不是插入其中。

最后,您的表名以数字开头,因此您需要对它们进行转义。

此 SQL 应该更好地工作:

update `1table` 
set url = (select db2.`2table`.url 
           from db2.`2table` 
           where `1table`.name = db2.`2table`.name);
于 2012-06-10T12:41:52.103 回答