我试着在网上查了一下,没找到什么。
假设如下:
create schema if not exists sb;
create table if not exists sb.test (id serial primary key);
insert into sb.test values (1), (2), (3);
个字符
为什么结果集是空的?
如果我这样做,那么它就像预期的那样工作:
select * from sb.test where id != any('{}'::int[])
-- [ { "id": 2 }, { "id": 3 } ]
型
如何获取返回所有记录的第一个查询?
1条答案
按热度按时间uurity8g1#
从你的注解中,你想要做的是从表中获取所有记录,除了你已经在其他地方(例如,在连接到你的数据库的应用程序中)构建的id列表。
我将演示在参数中使用非空数组的可能性:
你可以用
UNNEST
来实现:字符串
或者使用子查询(下面,使用
VALUES
):型
编辑:
正如我在评论中所说,下面的工作也是如此:
型
Id
3
确实不同于数组中的所有值。