自定义函数能否用表名作为参数??急!

ddboy 2005-09-20 10:45:21
我有一系统列列名相同的表保存用户的信息,如学历、职业...,这些表都只有 ID和name 两个字段
现在每次查询时都必须用:
(Select top 1 name From job_sys_edu where ID=edu) as eduname 这样的语句,想定义这样的函数

CREATE FUNCTION GetSysField(@fid int,@tableName varchar(30))
RETURNS varchar(50)
AS
BEGIN
DECLARE @str varchar(50)
SET @str = ''
SELECT top 1 @str = [name]
FROM @tableName WHERE ID = @fid
RETURN @str
END

但系统不允许这样定义函数,总提示tableName没定义,有没有办法解决这个问题呢?



...全文
374 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
bugchen888 2005-09-20
  • 打赏
  • 举报
回复
SQL Server 2000的用户自定义函数不支持动态SQL.
MorningTea 2005-09-20
  • 打赏
  • 举报
回复
function不行!
对于sp,有转换方法:
数据类型sysname,这是 SQL Server 用于存储对象名称的数据类型。
--不过其实用字符串存储表名就可以啦
create proc ADD_AddProduct
@attrValue varchar(10)
/*@attrValue sysname 也是可以的*/
as
begin
exec('select * from '+ @attrValue)
end
zjcxc 元老 2005-09-20
  • 打赏
  • 举报
回复
不能, 你执行的是动态的T-SQL语句, 这在函数中是不支持的
vivianfdlpw 2005-09-20
  • 打赏
  • 举报
回复
可以改用存储过程:
CREATE PROCEDURE GetSysField
@fid int,
@tableName varchar(30),
@str varchar(50) output
AS
BEGIN
DECLARE @SQL NVARCHAR(200)
SET @SQL='SELECT top 1 @str = [name]'
+'FROM '+@tableName+' WHERE ID = @fid'
EXEC SP_EXECUTESQL @SQL
,N'@str varchar(50) out,@fid inr'
,@str out,@fid
END

samfeng_2003 2005-09-20
  • 打赏
  • 举报
回复
好象可以,用sysname做为数据类型

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧