我有一个表值函数,它接受一个人的ID号并返回几行和一列.在另一个查询中,我正在创建一个SELECT,它可以检索有关很多人的大量信息.如何将我的主查询中的id号传递给我的函数来汇总列并将其加入我的主查询?我希望我没有表值函数,因为它可以很容易地工作,但是,这个函数在别处使用,我想重用它.也许这对于表值函数甚至不可能,我需要创建一个标量值.
我的主要查询如下所示:
select id_num, name, balance
from listOfPeople
Run Code Online (Sandbox Code Playgroud)
表值函数如下所示:
calculatePersonalDiscount(id_number)
Run Code Online (Sandbox Code Playgroud)
我想做的事情如下:
select id_num, name, balance
from listOfPeople
left join
(
SELECT id_num, SUM(discount)
FROM calculatePersonalDiscount(listOfPeople.id_num)
) x ON x.id_num = listOfPeople.id_num
Run Code Online (Sandbox Code Playgroud)
但是你不能将listOfPeople.id_num传递给函数,因为它的范围并不相同.
Mat*_*ton 44
在SQL Server 2005中,您可以使用CROSS APPLY语法:
select id_num, name, balance, SUM(x.discount)
from listOfPeople
cross apply dbo.calculatePersonalDiscount(listOfPeople.id_num) x
Run Code Online (Sandbox Code Playgroud)
同样地,还有一个OUTER APPLY语法,相当于LEFT OUTER连接.
| 归档时间: |
|
| 查看次数: |
30457 次 |
| 最近记录: |