在函数中怎样使用表名和字段名作为变量?
时间: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
作者: roy_88 发布时间: 2011-11-29
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28