+ -
当前位置:首页 → 问答吧 → 在函数中怎样使用表名和字段名作为变量?

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

时间:2011-11-29

来源:互联网


有以下函数
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  

作者: lsp69   发布时间: 2011-11-29

表名和列名不可以作變量,那只能用存儲過程或在函數調用擴展存儲過程

作者: roy_88   发布时间: 2011-11-29

真要實現,要用一個變通的方法
參照
动态列名数据视图实现
http://blog.csdn.net/roy_88/article/details/6883078

作者: roy_88   发布时间: 2011-11-29

热门下载

更多