sql中使用变量出错

目的:将数据库名设为变量,方便将来修改。如下T/SQL出错:declare@dbXFZvarchar(30)declare@SQLStringvarchar(500)se... 目的:将数据库名设为变量,方便将来修改。如下T/SQL出错:
declare @dbXFZ varchar(30)
declare@SQLString varchar(500)
select @dbXFZ="PantoSckoolXFZ.dbo."
select @SQLString="insert into XSK_Grade(NJDM,NJMC,RXNF,mark)SELECT NJDM,NJMC,RXNF,mark FROM "+@dbXFZ+"jx_Grade where NJDM not in (select NJDM from XSK_Grade)"
exec sp_executesql @SQLString

若不使用变量,则可以正常执行:
insert into
XSK_Grade
(NJDM,NJMC,RXNF,mark)
SELECT NJDM,NJMC,RXNF,mark
FROM pantoschoolxfz.dbo.jx_Grade
where
NJDM not in (select NJDM from XSK_grade)
注:此SQL代码是用来做数据库定时作业的。请高人指教。
展开
 我来答
华夏日长兴
2010-05-17 · TA获得超过9593个赞
知道大有可为答主
回答量:6305
采纳率:85%
帮助的人:3752万
展开全部
declare @dbXFZ varchar(30),@SQLString varchar(500)
select @dbXFZ='PantoSckoolXFZ.dbo.'
select @SQLString='insert into XSK_Grade(NJDM,NJMC,RXNF,mark)SELECT NJDM,NJMC,RXNF,mark FROM '+@dbXFZ+'jx_Grade where NJDM not in (select NJDM from XSK_Grade)'
exec (@SQLString)
luzhengdong
2010-05-17 · 超过24用户采纳过TA的回答
知道答主
回答量:153
采纳率:0%
帮助的人:74.4万
展开全部
insert into
XSK_Grade
values(NJDM,NJMC,RXNF,mark)
as SELECT NJDM,NJMC,RXNF,mark
FROM pantoschoolxfz.dbo.jx_Grade
where
NJDM not in (select NJDM from XSK_grade)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
MuCloudLi
2010-05-17 · TA获得超过480个赞
知道小有建树答主
回答量:802
采纳率:0%
帮助的人:747万
展开全部
把你的语句中的双引号全部改成单引号就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
chg010
2010-05-17 · TA获得超过102个赞
知道小有建树答主
回答量:116
采纳率:0%
帮助的人:111万
展开全部
select @SQLString="insert into XSK_Grade(NJDM,NJMC,RXNF,mark)SELECT NJDM,NJMC,RXNF,mark FROM "+@dbXFZ+"jx_Grade where NJDM not in (select NJDM from XSK_Grade)"
这句的双引号都改成单引号
另外
declare@SQLString varchar(500)找个长度最好设大一点,防止sql语句放不下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式