执行下面的存储过程总是报'<' 附近有语法错误。

createprocp_Add@tableNamenvarchar(20),@descriptionnvarchar(max)asdeclare@sqlnvarchar(... create proc p_Add
@tableName nvarchar(20),
@description nvarchar(max)
as
declare @sql nvarchar(max)
set @sql='insert into '+@tableName+'(Description) values('+@description+')'
exec sp_executesql @sql
go
exec p_Add 'Company','<p>\r\n a</p>\r\n'
展开
 我来答
szm341
2012-11-22 · TA获得超过6726个赞
知道大有可为答主
回答量:5005
采纳率:100%
帮助的人:5160万
展开全部
你可以直接用sp_executesql的参数化方法执行,请查阅sqlserver帮助文档
或拼接时记得多拼接单引号
set @sql='insert into '+@tableName+'(Description) values('''+@description+''')'
追问
alter proc p_Add
@tableName nvarchar(20),
@description nvarchar(max)
as
declare @sql nvarchar(max)
set @sql=N'insert into @tableName(Description)values(@description)'
exec sp_executesql @sql,N'@tableName nvarchar(20),@description nvarchar(max)',@tableName,@description
go
exec p_Add 'Company','\r\n a
\r\n'
我改了一下,但报必须声明表变量 "@tableName"。
追答
表这里还是拼接吧,因为你传进去会参数化成字符串
insert into 'company'不成立
百度网友f9f2af3
2012-11-22 · TA获得超过357个赞
知道小有建树答主
回答量:385
采纳率:0%
帮助的人:238万
展开全部
楼上说的对....
或是在执行时多加两个单引号,如下:
exec p_Add 't1','''<p>\r\n a</p>\r\n'''
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式