sp_executesql 求助!

asdf13225 2016-03-05 07:58:11

ALTER proc [dbo].[Proc_Decide_Field]
/** 判断表中是否存在某字段 **/
( @xTable Nvarchar(20),
@xField Nvarchar(20),
@M smallint output)
AS

Begin
declare @Sql as varchar(max)
set @Sql='
if exists(select * from PREVIOUS_FILE..syscolumns where id=object_id('+
'''PREVIOUS_FILE.dbo.'+@xTable+''''+') and Name='+''''+@xField+''''+')
set @M=1
else
set @M=0'

print @Sql
exec sp_executesql @Sql,N'@M int out',@M out
print @M
end


declare @K int
exec proc_decide_field '十二月','班级',@K output
结果显示:

if exists(select * from PREVIOUS_FILE..syscolumns where id=object_id('PREVIOUS_FILE.dbo.十二月') and Name='班级')
set @M=1
else
set @M=0
消息 214,级别 16,状态 2,过程 sp_executesql,第 1 行
过程需要类型为 'ntext/nchar/nvarchar' 的参数 '@statement'。
...全文
86 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
asdf13225 2016-03-06
  • 打赏
  • 举报
回复
问题解决了, 确实如shiyiwan所答: 需将@Sql 设为 NVarchar(max), 同时也要设为 N'@M int out',前面我说错误的原因是我不知什么原因 N'@M int out'少了一个 N .。
asdf13225 2016-03-06
  • 打赏
  • 举报
回复
非常感谢二位的回答。 将varchar改为 nvarchar 回复:我试了下:不行。结果还是与原来一样。 我将 Print @Sql 的结果复制到 sql server 中(当然要加上 declare @M int)单独执行,是可以通过的。
shiyiwan 2016-03-06
  • 打赏
  • 举报
回复
declare @Sql as varchar(max)
将varchar改为 nvarchar
asdf13225 2016-03-06
  • 打赏
  • 举报
回复
不行啊! 第一:Object_Id(@xTable)中的@xTable不需要用‘’引起来(@x Field也一样)? 第二:我查询的是另一个数据库中的字段,一定要加上 PREVIOUS_FILE
道玄希言 2016-03-05
  • 打赏
  • 举报
回复


Select Count(Name) as cnt  FROM SysColumns Where id=Object_Id(@xTable) and Name = @xField

cnt = 1 表示存在该字段.

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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