Sha*_*ehr 66 join sql-server syntax sql-server-2012 functions
我有一个用户定义的函数:
create function ut_FooFunc(@fooID bigint, @anotherParam tinyint)
returns @tbl Table (Field1 int, Field2 varchar(100))
as
begin
-- blah blah
end
Run Code Online (Sandbox Code Playgroud)
现在我想在另一张桌子上加入这个,就像这样:
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
Run Code Online (Sandbox Code Playgroud)
换句话说,所有的Foo记录,其中SomeCriterion1,我想看到的Foo ID和Desc,旁边的值Field1,并Field2认为从返回ut_FooFunc的的输入Foo.ID。
这样做的语法是什么?
Mar*_*ith 104
你不需要CROSS APPLY加入。
连接中涉及的表表达式的定义必须是稳定的。即它们不能相关联,以至于表表达式的含义取决于另一个表中行的值。
select f.ID, f.Desc, u.Field1, u.Field2
from Foo f
Cross apply ut_FooFunc(f.ID, 1) u
where f.SomeCriterion = ...
Run Code Online (Sandbox Code Playgroud)