繁体   English   中英

获取WHERE中的所有字段

[英]Get all fields in WHERE

我正在使用Oracle数据库。 对于这个数据库,我必须编写一个过滤器。 我正在WHERE sql子句中进行过滤。

但是,如果过滤器不是完整的,我想设置SELECT * FROM Person WHERE Name = '*' 这是行不通的。 是否有任何建议如何将WHERE clause设置为所有names而不将其保留呢?

感谢您的回答!

我将“如何将WHERE子句设置为所有names又不遗漏”的解释为:“我希望字段Name出现在WHERE子句中,但我希望所有记录。

... WHERE Name like '%' or Name is null

将返回所有行(我很确定like '%'也会匹配空字符串)

过滤器的编码应动态排除或包括所选字段。 换句话说:类似于此动态创建查询字符串

whereClause = '1=1';
foreach (filter in filterConditions) {
  if (!filter.IsEmpty) {
    whereClause += ' AND '+filter.SQLExpression
  }
}

抱歉,我对Java不熟悉,但是希望您能理解。 当然,您仍然应该引入参数(在filter.SQLExpression编码),而不是直接将过滤器值编码到SQLExpression中。

您必须使用SELECT * FROM Person WHERE Name like '%'

SQL通配符是%不是asterix 启用通配符搜索的运算符也是如此。

如果“ Name列必须是在表中进行搜索的唯一条件,请尝试以下方式:

SELECT * 
FROM Person 
WHERE Name IN ( select distinct Name --fetch distinct names 
                from Person ) --and then search through it

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM