我有一个表,看起来像这样:
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的行:
SELECT * FROM mytable WHERE p_id = ? AND j_id = ? LIMIT 10我想扩展这个查询,以便它也排除一些行,例如,我有一个这样的列表:
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?
例如,(不是真正的代码),类似于:
SELECT * FROM mytable WHERE p_id = ? AND j_id = ?
AND NOT IN(rowsToExclude)
LIMIT 10相关信息:
发布于 2021-05-05 22:25:35
您可以使用八个参数,而不是只使用两个。
例如,您可以执行以下操作:
SELECT *
FROM mytable
WHERE p_id = ? AND j_id = ?
and (p_id, j_id, u_id) not in ((?, ?, ?), (?, ?, ?))
LIMIT 10我假设1、3、5、7、8和9是字符串,因为表列是VARCHAR。
注释:此策略不适用于空值。
https://stackoverflow.com/questions/67402962
复制相似问题