通过在 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 中传递变量参数来加入表值函数的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server 表变量和临时表的区别

SQL SERVER2000将多行查询结果拼接到一行数据

解决 U2000 R017 安装报错: 检查SQL server数据库环境变量信息 ( 异常 ) [ 详细信息 ] PATH环境变量中缺少数据库路径的信息

sql server2008备份出来的数据库如何在在sql server 2005或2000中还原

如何通过 SQL 查询显示 SQL Server 2000 服务器角色

在sql server中一次插入固定数量的行2000