读书人

在函数中怎样使用表名和字段名作为变量

发布时间: 2012-03-13 11:21:11 作者: rapoo

在函数中怎样使用表名和字段名作为变量?

有以下函数
create table tb(id int, value varchar(10))
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go
--1. 创建处理函数
CREATE FUNCTION dbo.f_strUnite(@id int)
RETURNS varchar(8000)
AS
BEGIN
DECLARE @str varchar(8000)
SET @str = ''
SELECT @str = @str + ',' + value FROM tb WHERE id=@id
RETURN STUFF(@str, 1, 1, '')
END
GO
-- 调用函数
SELECt id, value = dbo.f_strUnite(id) FROM tb GROUP BY id
drop table tb
drop function dbo.f_strUnite
go
/*
id value
----------- -----------
1 aa,bb
2 aaa,bbb,ccc
(所影响的行数为 2 行)
*/

要变成这样怎么写?表名字段名字段值都是变量
我这样写执行不了:
CREATE FUNCTION dbo.f_strUnite(@Table varchar(300),@Field varchar(300),@idField int,@id int)
RETURNS varchar(8000)
AS
BEGIN
DECLARE @s varchar(8000)
DECLARE @str varchar(8000)
SET @str = ''
set @s='SELECT ' + @str = @str + ',' + @Field + ' FROM ' + @Table + ' WHERE ' + @idField + '= ' + @id
RETURN STUFF(@str, 1, 1, '')
END



[解决办法]
真要,要用一通的方法

动态列名数据视图实现
http://blog.csdn.net/roy_88/article/details/6883078
[解决办法]
改存程方法

SQL code
CREATE PROCEDURE dbo.f_strUnite(    @Table varchar(300),    @Field varchar(300),    @idField int,    @id INT,    @str nvarchar(1000)  output)  AS  BEGIN    DECLARE @s nvarchar(4000)    SET @str = ''    set @s='SELECT @str=@str+'',''+'+ @Field + ' FROM ' + @Table + ' WHERE ' + @idField + '= ' + @id    EXEC sp_executesql @s,N'@str nvarchar(1000)  output ',@str output  set @str= STUFF(@str, 1, 1, '')  END  GO 

读书人网 >SQL Server

热点推荐