使用此查询:
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 ...)?
由于
答案 0 :(得分:7)
您应该使用OUTER APPLY
或CROSS APPLY
而不是光标:
SELECT *
FROM ( SELECT id
FROM org.employees
WHERE {some_condition}) A
OUTER APPLY org.work_schedule(A.id, @fromDate, @toDate) B