通过在 SQL Server 2000 中传递变量参数来加入表值函数
Posted
技术标签:
【中文标题】通过在 SQL Server 2000 中传递变量参数来加入表值函数【英文标题】:join a table valued function by passing variable argument in SQL Server 2000 【发布时间】:2011-08-22 11:09:03 【问题描述】:我有一个表值函数,它接受一个参数并返回四个值。我需要使用联接为表中的每一行调用此函数,但似乎 SQL Server 2000 不允许使用联接将变量参数传递给表值函数。我可以在 SQL Server 2005 或 2008 中使用“CROSS APPLY”来实现这一点,但是在 SQL Server 2000 中是否有任何解决方法?
我想做这样的事情
select t1.val1, f.val2, f.val3, f.val4
from tbl1 t1
join dbo.tableFunc(t1.val1) f on t1.val1 = f.val1
【问题讨论】:
【参考方案1】:文档说只有常量和@local_variables 可以传递给表值函数(参见here)。我看不到 UDF 的解决方法。 但我认为您可以在查询之外使用表值函数的主体。
【讨论】:
以上是关于通过在 SQL Server 2000 中传递变量参数来加入表值函数的主要内容,如果未能解决你的问题,请参考以下文章
解决 U2000 R017 安装报错: 检查SQL server数据库环境变量信息 ( 异常 ) [ 详细信息 ] PATH环境变量中缺少数据库路径的信息
sql server2008备份出来的数据库如何在在sql server 2005或2000中还原