加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLITE – INSERT或UPDATE而不更改ROWID值

发布时间:2020-12-12 18:55:09 所属栏目:百科 来源:网络整理
导读:我需要更新表行IF EXISTS,否则INSERT一个新行. 我试过了: INSERT OR REPLACE INTO table VALUES ... 但如果行行存在,则此语句会更改行的ROWID,这就是我要避免的(我需要rowid:D) 我还试图找到一种从更新获得某种返回值的方法,在发生更新的情况下,但我仍然不
我需要更新表行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")

解决方法

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读