0

我想对我的选择子查询应用条件检查。我怎样才能做到最好?

这是初始查询:

SELECT 
  table1.column1, 
  (SELECT min(table2.column1) FROM table2 WHERE table2.table1Id = table1.id) as subResult
FROM table1
WHERE table1.column2 = "something"

我想添加 WHERE 条件subResult = :parameter。并且:parameter是可选的,意思是如果:parameter为空,则在结果中包含行。

WHERE table1.column2 = "something" AND (:parameter is null or subResult = :parameter)

但是我无法subResult在 WHERE 条件中引用子查询的结果。

我可以将子查询复制/粘贴到 WHERE 子句中,但这似乎很草率且容易出错:

SELECT 
  table1.column1, 
  (SELECT min(table2.column1) FROM table2 WHERE table2.table1Id = table1.id) as subResult
FROM table1
WHERE table1.column2 = "something" AND (:parameter is null or (SELECT min(table2.column1) FROM table2 WHERE table2.table1Id = table1.id) = :parameter)
4

2 回答 2

2

如果您运行的是 Oracle 12 或更高版本,我建议您使用横向连接:

select t1.column1, t2.min_column1
from table1 t1
outer apply (select min(t2.column1) min_column1 from table2 t2 where t2.table1id = t1.id) t2
where 
    t1.column2 = 'something' 
    and (:parameter is null or t2.min_column1 = :parameter)

在早期版本中,您可以使用子查询或 CTE:

select *
from (
    select t1.column1, 
        (select min(t2.column1) from table2 t2 where t2.table1id = t1.id) as min_column1
    from table1 t1
) t
where 
    t1.column2 = 'something' 
    and (:parameter is null or t2.min_column1 = :parameter)
于 2020-10-23T20:29:38.393 回答
1
select * 
from  (SELECT 
         table1.column1, 
        (SELECT min(table2.column1) FROM table2 WHERE table2.table1Id = table1.id) as  subResult
    FROM table1
    WHERE table1.column2 = "something"
    )
where   subResult = decode(:p,null , subResult ,:p)
于 2020-10-23T20:10:25.213 回答