SQLITE – INSERT或UPDATE而不更改ROWID值

SQLITE – INSERT或UPDATE而不更改ROWID值,第1张

概述我需要更新表行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 ……旧的时尚,但保证工作. 总结

以上是内存溢出为你收集整理的SQLITE – INSERT或UPDATE而不更改ROWID值全部内容,希望文章能够帮你解决SQLITE – INSERT或UPDATE而不更改ROWID值所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1150196.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存