【发布时间】:2014-03-13 04:36:16
【问题描述】:
我正在使用 dapper.net 和 sqlite。当我执行此查询时,只有第一个 id 被插入,其余的被忽略。如何批量插入?
insert or ignore into pair(key, value)
select @key, (select value from list where id in @id_list)
【问题讨论】:
我正在使用 dapper.net 和 sqlite。当我执行此查询时,只有第一个 id 被插入,其余的被忽略。如何批量插入?
insert or ignore into pair(key, value)
select @key, (select value from list where id in @id_list)
【问题讨论】:
没有 FROM 子句的 SELECT 查询将生成一条记录:
> SELECT 42;
42
当您将子查询放入该 SELECT 列表时,该子查询是 scalar subquery,它只返回一个值。
要为查询中的每条记录返回一个常量值,您必须将该常量放入该查询的 SELECT 子句中:
INSERT OR IGNORE INTO pair(key, value)
SELECT @key, value FROM list WHERE id IN (1,2,3,...)
【讨论】: