SQLITE-在不更改ROWID值的情况下进行INSERT或UPDATE

BeN*_*ErR 5 sqlite sql-update

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

INSERT OR REPLACE INTO table VALUES ...
Run Code Online (Sandbox Code Playgroud)

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

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

您对此问题有任何建议或解决方案吗?还是我需要制作ROWID的副本并使用它代替“纯”表ROWID?

在此先感谢您,最好的问候

ps:我在这里找,我想知道sqlite是否也有OUTPUT特殊词,但是google并没有帮助我。

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

表架构示例

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")
Run Code Online (Sandbox Code Playgroud)

Chr*_*ris 1

除了作为主键之外,您还需要指定您的table_idis :unique

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
Run Code Online (Sandbox Code Playgroud)