如何以编程方式使用包含多列的 where-in 子句执行 PostgreSQL 查询?

2024-05-14

我的查询是这样的:

select * from plat_customs_complex
where (code_t,code_s) 
in (('01013090','10'),('01029010','90'));

它在 psql 控制台中运行良好。我的问题是如何在客户端代码中执行此查询。(通过 C# 或 Java)

我已经知道以下代码运行良好(C#):

string[] codeT = new string[]{"01013090","01029010"};    
connection.Query("SELECT * FROM plat_customs_complex WHERE code_t=ANY(@CodeT)",
new { CodeT = codeT });

最后,我找到了unnest功能可以提供帮助。

纯SQL是这样的:

select * from plat_customs_complex
where (code_t,code_s) = ANY(select * from unnest(ARRAY['01013090','01029010'],ARRAY['10','90']))

可以轻松地将其转换为 C# 代码:

string[] codeTs = new string[]{"01013090","01029010"}; 
string[] codeSs = new string[]{"10", "90"};
connection.Query("select * from plat_customs_complex
where (code_t,code_s) = ANY(select * from unnest(@CodeTs, @CodeSs))", 
new {CodeTs=codeTs, CodeSs=codeSs});
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何以编程方式使用包含多列的 where-in 子句执行 PostgreSQL 查询? 的相关文章

随机推荐