9

如果存在,我需要更新表行,否则插入新行。我试过了:

INSERT OR REPLACE INTO table VALUES ...

但是如果行行存在,则此语句会更改行的 ROWID,这就是我要避免的(我需要 rowid :D)

我还试图找到一种从更新中获取某种返回值的方法,在发生更新的情况下,但我仍然不明白如何......如果我可以从更新语句中获取返回值,我可以选择是否继续插入。

您对这个问题有什么建议或解决方案吗?或者我是否需要制作 ROWID 的副本并使用它而不是“纯”表 ROWID?

在此先感谢,最好的问候

ps:我在看这里,我想知道sqlite是否也有 OUTPUT 特殊词,但谷歌没有帮助我..

----阅读评论后编辑:

表架构示例

CREATE TABLE test (
    table_id TEXT NOT NULL,
    some_field TEXT NOT NULL,
    PRIMARY KEY(table_id)
)

INSERT or REPLACE INTO test (table_id, some_field) VALUES ("foo","bar")
4

4 回答 4

4

我测试了 Chris 的建议,但 rowid 仍然发生了变化。我认为最好的选择是执行 SELECT 以查看是否已经存在具有该键的行。如果是这样,请更新,否则,插入...不错的旧时尚,但保证可以工作。

于 2012-11-27T20:57:36.177 回答
3

把它和select结合起来,像这样

INSERT or REPLACE INTO test (ROWID, table_id, some_field)
VALUES ((SELECT ROWID from test WHERE table_id = 'foo' UNION SELECT max(ROWID) + 1 from test limit 1), 'foo','bar')
于 2017-10-18T10:50:49.110 回答
1

您需要指定您的table_idisunique除了是主键:

sqlite> CREATE TABLE test (
    table_id TEXT NOT NULL,
    some_field TEXT NOT NULL,
    PRIMARY KEY(table_id),
    UNIQUE(table_id)
);

sqlite> insert or replace into test values("xyz", "other");
sqlite> select * FROM test;
xyz|other
sqlite> insert or replace into test values("abc", "something");
sqlite> insert or replace into test values("xyz", "whatever");
sqlite> select * FROM test;
abc|something
xyz|whatever
于 2012-08-03T14:28:34.890 回答
0

From version 3.24.0 (2018-06-04), SQLite now supports an UPSERT clause that will do exactly what the OP needed: https://www.sqlite.org/lang_UPSERT.html

The insert would now look like this:

INSERT INTO test (table_id, some_field) VALUES ("foo","baz")
ON CONFLICT(table_id) DO UPDATE SET some_field=excluded.some_field;
于 2022-01-12T17:10:29.473 回答