2

SQL Server (2000/2005) 函数获取表名和字段名作为参数,并从函数内的动态查询返回结果。结果应分配给Table将在存储过程中进一步使用的变量。如何做到这一点?

我收到错误消息:“只能从函数中执行函数和扩展存储过程。”

Declare @Data as table (FieldValue varchar(100))
insert into @Data select * from MyFunction ('Person.Address','AddressID')     

-- Function
Alter function MyFunction (
   @TableName varchar(100), @FieldName varchar(100) 
) returns @GetData table (
   FieldValue  varchar(100) 
) as
begin
        Declare @SQL varchar(250)
        Set @SQL = 'Select '+@FieldName+ ' from '+ @TableName
        Exec sp_executesql @SQL     
        return
end
4

3 回答 3

8

只是为了关闭循环......

这是调用函数并将这些结果放入表变量中的语法

@simons 解决方案的小型构建

这在 sql2012 和 sql2014 上运行。

[不要忘记关闭表格语句。如果您将表格全部放在一行上,这很容易做到。]

declare @t table(field1  nvarchar(100) )

insert @t select * from dbo.Cool_1Field_Function( 'parm1' ,'parm2')
select * from @t
于 2016-12-12T16:46:32.203 回答
1

我不确定这如何与函数一起使用,但如果您有一个返回结果集的存储过程,您可以使用 INSERT EXEC 语句将其插入到表变量中。

INSERT @TableVariable
EXEC spYourProcedure

只要字段匹配就可以了。否则,您可以使用:

INSERT @TableVariable (FieldInSp1, FieldInSp2)
EXEC spYourProcedure

这样您就可以在存储过程之间传递数据。有关一些额外信息,请参阅INSERT EXEC 语句的此页面。

于 2009-01-21T05:52:08.613 回答
1

您不能在用户定义的函数中使用“exec”。UDF 必须没有副作用。

于 2009-01-21T10:24:59.403 回答