StopWatch 2017-08-26 01:24 采纳率: 0%
浏览 2201

sql触发器提示未知对象的问题

我尝试在sql中写一个触发器,要求是在我insert之前,把原表做备份,写的代码如下
create trigger cfq on ss.dbo.cj
instead of insert
as
begin
declare @id int
declare @math int
declare @phyc int
declare @eng int
select @id = id,@math = math,@phyc = phyc,@eng = eng from ss.dbo.cj
create ss.cj_bak as select * from ss.dbo.cj
end
go

现在提示我的备份表ss.cj_bak 消息 343,级别 15,状态 1,过程 cfq,第 10 行
CREATE、DROP 或 ALTER 语句中使用了未知的对象类型 'ss'。

请问是什么问题

  • 写回答

1条回答 默认 最新

  • HuangDanGeeker 2017-08-26 02:11
    关注

    create ss.cj_bak as select * from ss.dbo.cj
    这一行出错,尝试把第一个 ss. 去掉

    而且 逻辑上是有错误的
    create ss.cj_bak as select * from ss.dbo.cj

    当你第二次insert,触发触发器的话,第一次已经执行了create cj.bak,即cj.bak已经存在,此时第二次create cj.bak,会出现错误
    解决方案:在create cj.bak 之前,先 delete if exist cj.bak

    评论

报告相同问题?

悬赏问题

  • ¥15 matlab实现基于主成分变换的图像融合。
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊