首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从select查询中排除基于多列的行

从select查询中排除基于多列的行
EN

Stack Overflow用户
提问于 2021-05-05 22:08:13
回答 1查看 35关注 0票数 0

我有一个表,看起来像这样:

代码语言:javascript
运行
复制
CREATE TABLE public.mytable (
  p_id varchar(40) NOT NULL,
  j_id varchar(48) NOT NULL,
  u_id varchar(255) NOT NULL
);

我使用以下代码来查找基于p_id和j_id的行:

代码语言:javascript
运行
复制
SELECT * FROM mytable WHERE p_id = ? AND j_id = ? LIMIT 10

我想扩展这个查询,以便它也排除一些行,例如,我有一个这样的列表:

代码语言:javascript
运行
复制
class MyEntity {
    public p_id 
    public j_id;
    public u_id;
}

List<MyEntity> rowsToExclude = new ArrayList<>();
rowsToExclude.add(new MyEntity(1, 3, 5));
rowsToExclude.add(new MyEntity(7, 8, 9));

如何将rowsToExclude提供给查询,比如使用NOT IN?

例如,(不是真正的代码),类似于:

代码语言:javascript
运行
复制
SELECT * FROM mytable WHERE p_id = ? AND j_id = ? 
AND NOT IN(rowsToExclude)
LIMIT 10

相关信息:

Select NOT IN multiple columns

Can you use multiple columns for a not in query?

EN

Stack Overflow用户

发布于 2021-05-05 22:25:35

您可以使用八个参数,而不是只使用两个。

例如,您可以执行以下操作:

代码语言:javascript
运行
复制
SELECT * 
FROM mytable 
WHERE p_id = ? AND j_id = ?
  and (p_id, j_id, u_id) not in ((?, ?, ?), (?, ?, ?))
LIMIT 10

我假设135789是字符串,因为表列是VARCHAR

注释:此策略不适用于空值。

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

https://stackoverflow.com/questions/67402962

复制
相关文章

相似问题

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