gpt4 book ai didi

sql - 如果表为空,则将行插入表中,如果不在 SQLite 中,则替换现有行

转载 作者:行者123 更新时间:2023-12-03 17:46:17 25 4
gpt4 key购买 nike

我在 SQLite 3 中有一个表:

CREATE TABLE foo
(
bar TEXT
);

它总是有 0 或 1 行。我想编写一个查询,如果有 1 行则更新该行,如果有 0 行则添加该行。最干净的方法是什么?

最佳答案

如果您可以再添加一个唯一字段,那么您可以:

INSERT OR REPLACE INTO foo (id, bar) VALUES (1, ?);

本例中的建表是:

CREATE TABLE foo (id INTEGER NOT NULL, bar TEXT, UNIQUE (id));

或者正如 Alexey 发现的那样,没有主键:

INSERT OR REPLACE INTO foo (rowid, bar) VALUES (1, ?);

关于sql - 如果表为空,则将行插入表中,如果不在 SQLite 中,则替换现有行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3976826/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com