对同一查询中另一个SELECT的所有返回行执行SELECT

时间:2013-10-23 16:01:50

标签: c# sql sql-server-2008

使用此查询:

SELECT id FROM org.employees WHERE {some_condition}

对于上述查询中的每一行,我需要调用:

SELECT * FROM org.work_schedule(@employeeId, @fromDate, @toDate)

其中org.work_schedule是表值函数,用于处理所有员工的可用工作时间表和约束,并返回两个DATETIME(开始,结束)列,表示给定员工在提供的日期范围内的可用性。

我正在考虑在第一个查询上使用游标并提供一个将返回的临时表。这是唯一的解决方案吗?

该项目在C#中,我也可以直接在C#中完成此任务,但我怀疑在SQL中完全执行此操作会更加优化(SQL Server 2008)。

这似乎是本地化的,我会用以下方式概括这个问题:

如何为另一个查询(SELECT)返回的每一行执行查询(SELECT)并在一次调用中返回整个结果(动态执行SELECT UNION SELECT UNION ...)?

由于

1 个答案:

答案 0 :(得分:7)

您应该使用OUTER APPLYCROSS APPLY而不是光标:

SELECT *
FROM (  SELECT id 
        FROM org.employees 
        WHERE {some_condition}) A
OUTER APPLY org.work_schedule(A.id, @fromDate, @toDate) B