微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql-server – 如何使用表值函数连接表?

我有一个用户定义的功能
create function ut_FooFunc(@fooID bigint,@anotherParam tinyint)
returns @tbl Table (Field1 int,Field2 varchar(100))
as
begin
  -- blah blah
end

现在我想在另一个表上加入这个,就像这样:

select f.ID,f.Desc,u.Field1,u.Field2
from Foo f 
join ut_FooFunc(f.ID,1) u -- doesn't work
where f.someCriterion = 1

换句话说,对于SomeCriterion为1的所有Foo记录,我想看到Foo ID和Desc,以及从ut_FooFunc返回的Foo.ID输入的Field1和Field2的值.

这样做的语法是什么?

解决方法

你需要交叉申请不加入.

连接中涉及的表表达式的定义必须是稳定的.即它们不能相关,因此表表达式意味着取决于另一个表中行的值的不同.

select f.ID,u.Field2
from Foo f 
Cross apply ut_FooFunc(f.ID,1) u
where f.someCriterion = ...

原文地址:https://www.jb51.cc/mssql/79963.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐