SQLITE - INSERT或UPDATE而不更改ROWID值

时间:2012-07-30 09:53:59

标签: sqlite sql-update

我需要更新表行IF EXISTS,否则INSERT一个新行。 我试过了:

INSERT OR REPLACE INTO table VALUES ...

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

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

您对此问题有任何建议或解决方案吗?或者我是否需要复制ROWID并使用它而不是“纯”表ROWID?

提前致谢,最好的问候

ps:我正在寻找HERE,我想知道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")

3 个答案:

答案 0 :(得分:3)

我测试了Chris的建议但是rowid仍然被改变了。我认为最好的替代方法是执行SELECT以查看是否已存在具有该键的行。如果是这样,更新,否则,INSERT ......旧时尚,但保证工作。

答案 1 :(得分:2)

将它与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')

答案 2 :(得分:0)

除了作为主键之外,您还需要指定table_idunique

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