请问sql语句中@@error返回的执行错误代码一般都是什么错误呀?语句执行都错误了怎么还能返回错误代码呢?

如题~... 如题~ 展开
 我来答
匿名用户
2013-06-20
展开全部
@@error是标示上一次的错误语句的错误代码,什么错误都有可能啊,关键看你上一个执行出错的是什么语句了。这个不是返回的,是系统记录的。当你执行一条错误语句后,系统就将错误代码记录到这个变量上,你可以通过这个变量的值来判断上一个过程或者语句是否出错啊。比如你循环执行一个插入,插入到中间的时候一条记录出错了,但是真个插入还是执行完了,这个时间你要判断整个插入是否成功以便决定是否提交,你就可以查看@@error码来判断了,如果是0标示你上一段插入没有一次错误。否则就是有错误了,你就可以回滚了。懂了么?亲╭(╯3╰)╮?
更多追问追答
追问
循环执行一个插入,插入到中间的时候一条记录出错了,但是真个插入还是执行完了,什么叫插入到中间的时候一条记录出错了?出错了还能执行完?
追答
自己多看看吧。
WHITE_WIN
推荐于2017-12-15 · TA获得超过6111个赞
知道大有可为答主
回答量:3759
采纳率:50%
帮助的人:2006万
展开全部

@@ERROR是返回最后执行的 Transact-SQL 语句的错误代码。

在可能出错的语句后面放是检查@@ERROR的语句,就可以将错误按照自已的方式处理:

下面的示例用 @@ERROR 在一个 UPDATE 语句中检测限制检查冲突(错误 #547),提交错误信息,退出过程。

UPDATE authors SET au_id = '172 32 1176'
    WHERE au_id = "172-32-1176"
  IF @@ERROR = 547  BEGIN
  RAISERROR('A check constraint violation occurred',16,1)--提交错误信息。
  RETURN--退出过程
  END

错误信息有很多6-7千条,可以在系统表sysmessages中查看错误代码和错误信息

本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式