首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Postgresql - "IN empty array“语法

Postgresql - "IN empty array“语法
EN

Stack Overflow用户
提问于 2020-09-15 23:32:51
回答 2查看 38关注 0票数 0

我以编程方式创建对Postgresql的sql查询,如下所示:

代码语言:javascript
运行
复制
SELECT * FROM table WHERE column IN (1, 2, 3);
SELECT * FROM table WHERE column IN (1);
SELECT * FROM table WHERE column IN ();

最后一个查询会生成一个语法错误。我该如何处理这种特殊情况,并在这里写一个空数组呢?

EN

回答 2

Stack Overflow用户

发布于 2020-09-15 23:47:40

在内部,

代码语言:javascript
运行
复制
col IN (1, 2, 3)

被转换为

代码语言:javascript
运行
复制
col = ANY (ARRAY[1,2,3]::integer[])

该语法也适用于空数组:

代码语言:javascript
运行
复制
col = ANY (ARRAY[]::integer[])
票数 1
EN

Stack Overflow用户

发布于 2020-09-15 23:43:01

使用不返回任何结果的子查询:

代码语言:javascript
运行
复制
select null where 0 = 1

这里的null也应该可以隐式转换为任何类型。重要的是,查询不返回任何结果。对于您的情况,可以使用select 0或其他整数,如果它们对您来说更清楚的话。

虽然您可以将文字null值插入到列表中,但我不建议这样做。有些平台的服务器设置允许null相等性测试。我怀疑优化器会更好地处理子查询表单。虽然这不能在不添加from dual的情况下在Oracle上工作,但它通常也是可移植的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63905200

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档