自定义函数出错,请兄弟们帮我看看

fyming 2006-01-18 04:34:23
CREATE FUNCTION cus_f_IsUsed
(
@lngID int=0,
@v int=0
)

RETURNS bit

AS

BEGIN

declare
@sql nvarchar(1000),
@IsUsed bit,
@Fields1 nvarchar(30),
@ID int

--字段名1变量(ID)
set @Fields1=case when @v=1800 then N'lngProvinceID'--省份
when @v=2000 then N'lngCityID'--城市
when @v=2200 then N'lngSepcialtyID'--专业
when @v=2400 then N'lngNationID'--民族
when @v=2600 then N'lngDiplomaID'--学历
when @v=2800 then N'lngWorkTypeID'--工种
when @v=3000 then N'lngProcessID'--工序
when @v=3200 then N'lngWorkPositionID'--工位
when @v=3400 then N'lngEmployeeTypeID'--员工类别
when @v=3600 then N'lngEmployeeQualityID'--员工性质
when @v=3800 then N'lngDutyID'--职务
when @v=4000 then N'lngTitleID'--职称
when @v=4200 then N'lngCusTypeID'--客户类别
when @v=4400 then N'lngCusGrpID'--客户组别
when @v=4600 then N'lngCusPropertyID'--企业性质
when @v=4800 then N'lngCusTradeID'--行业
end

set @IsUsed=0

--employee
if @v<>5000
begin
set @sql=N'select @F='+@Fields1+N' from employee where ' +@Fields1+N'=@ID'
exec sp_executesql @sql,
N'@F int out,@ID int',@ID out,@lngID
if @ID is not null
begin
set @IsUsed=1
goto aa
end
end

aa:
return @IsUsed
____________________________________________________________________

在查询分析器里执行
'select dbo.cus_f_IsUsed (3,1800)',
提示'服务器: 消息 557,级别 16,状态 2,过程 cus_f_IsUsed,行 44
只有函数和扩展存储过程才能从函数内部执行。'

什么意思?
...全文
97 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
zlp321002 2006-01-18
  • 打赏
  • 举报
回复
函数不能用动态SQL,改存储过程方式!!
fyming 2006-01-18
  • 打赏
  • 举报
回复
我测试过,只是在执行到
exec sp_executesql @sql,
N'@F int out,@ID int',@ID out,@lngID
这一句时才出错,那么错误提示中的"只有函数和扩展存储过程才能从函数内部执行"是什么意思?
尚和空四 2006-01-18
  • 打赏
  • 举报
回复


给你个例子看看吧。





CREATE FUNCTION dbo.func_getdate
(@date datetime)
RETURNS varchar(10)
AS
BEGIN
declare @y varchar(4)
declare @m varchar(2)
declare @d varchar(2)
declare @dt varchar(10)

set @y = convert(varchar(4),year(@date))
set @m = convert(varchar(2),month(@date))
set @d = convert(varchar(2),day(@date))
set @dt = @m + '/' + @d + '/' + @y
if @dt = '1/1/1900'
set @dt = ''
if @dt = '01/01/1900'
set @dt = ''
if @dt = '12/31/9999'
set @dt = ''
return @dt
END








【IEEE复现】永磁同步电机扩展状态观测器+无模型预测电流控制(MFPCC-ESO)与传统模型预测MPCC对比精确参数和失配参数仿真内容概要:本文围绕永磁同步电机(PMSM)的先进控制策略展开,重点复现并对比了基于扩展状态观测器的无模型预测电流控制(MFPCC-ESO)与传统模型预测电流控制(MPCC)在精确参数和参数失配条件下的仿真性能。该研究属于IEEE高水平论文复现,旨在通过Matlab/Simulink仿真验证MFPCC-ESO在抑制模型不确定性、外部扰动及参数偏差方面的优越鲁棒性。文中详细构建了两种控制策略的系统模型,分析了扩展状态观测器(ESO)对系统总扰动的实时估计与补偿能力,并通过仿真结果展示了MFPCC-ESO在动态响应、稳态精度和抗干扰能力上的显著优势。; 适合人群:具备电机控制、现代控制理论及Matlab/Simulink仿真基础的电气工程、自动化及相关专业的研究生、科研人员和工程技术人员。; 使用场景及目标:①深入理解无模型预测控制(MFPCC)与扩展状态观测器(ESO)的结合机理;②掌握永磁同步电机高性能控制策略的设计与仿真方法;③对比分析传统MPCC与新型MFPCC-ESO在参数敏感性方面的差异,为实际工程中应对参数失配问题提供解决方案。; 阅读建议:读者应结合提供的Matlab代码进行仿真复现,重点关注ESO的设计参数(如带宽)对观测效果的影响,以及MFPCC的成本函数构建逻辑。建议在精确参数和人为引入失配参数两种工况下分别运行,通过对比电流响应波形、转速波动等指标,深刻体会所提方法的鲁棒性优势。

34,874

社区成员

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

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