存储过程中肯定使用到了@FYear,而你没有声明这个变量。
decalre @FYear 类型
如果你声明了,那你把语法写出来吧,肯定是哪个地方不小心写错了。
看您贴出的代码,可不只是这个提示这个错误了。
首先你的@sqlstr没声明
后边的set @sqlstr = @sqlstr + 加号的后边都是字符串的部分,也就是说,存储过程的两个参数,都被你引到了单引号当中,那么就失去了传值的作用了,成了字符串的一部分了。
还有select @sqlstr=@sqlstr+',coalesce(p.'+FEmpField+',0)' from cz_t_gzfl order by fid,这个返回行数是一行吧?如果是多行,这个没办法赋值的。
你的存储过程有参数吧?你调用存储过程时,没有提供这个参数