我有 t-sql 插入查询到表 [foo] (bar_id int 主键自动增量,bar_name varchar) 和文本:
INSERT INTO foo(bar_name)
VALUES (@bar_name_new);
IF @@ROWCOUNT > 0
SELECT bar_id, bar_name
FROM foo
WHERE bar_id = scope_identity();
触发器可以在插入后修改 bar_name 字段。这就是为什么我需要刷新“bar_name”字段。
现在我需要在 sqlite db 上做同样的事情。我写过这个:
INSERT INTO foo(bar_name)
VALUES (@bar_name_new);
SELECT bar_id, bar_name
FROM foo
WHERE bar_id = (SELECT last_insert_rowid());
我可以检查数据库中调用 sqlite changes() 函数的更改次数。我知道sqlite中的case语句。但是我怎么能告诉sqlite当changes()返回0时不需要做select?
最佳答案
SQLite 的 SQL 风格没有 T-SQL 具有的分支和循环结构。控制流逻辑在宿主语言中执行。
在您的情况下,您需要 sqlite3_changes功能。无论如何,您将需要它来决定是否要检索任何行。虽然,为了方便和效率,您不妨只执行查询 where changes() > 0
如果(我怀疑)查询计划器足够聪明,可以立即返回。
关于sql-server - Sqlite 中的 TSQL "IF @@Rowcount > 0"模拟?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10671931/