SQL Msg 18054, Level 16, State 1
今天接到一个看起来很简单的任务--修改数据库中的一项数据。听起来很简单吧。
在网上搜索了一下,很快就拼凑出了相应的 SQL 语句:
UPDATE [suivi].[dbo].[numSerie]
SET ni_numCible = 'HF17263N7P13340'
WHERE ni_num = 'HF17262A1400234'
通过以上语句也可以看出来,任务很简单,在 [suivi].[dbo].[numSerie] 表中,查找 ni_num = 'HF17262A1400234' 的记录,将该条记录的 ni_numCible 字段设置为 'HF17263N7P13340'。
出乎意料,在执行了以上语句之后,出现了以下提示:
Msg 18054, Level 16, State 1, Procedure tg_InsUpdCible, Line 31
Error 50010, severity 16, state 1 was raised, but no message with that error number was found in sys.messages. If error is larger than 50000, make sure the user-defined message is added using sp_addmessage.
Msg 3609, Level 16, State 1, Line 1
The transaction ended in the trigger. The batch has been aborted.
执行完后不是应该出现 “xx Rows afftectd” 的吗,作为 SQL 小白的我,对于这一大堆提示信息,表示看不懂。
好吧,上 Google 上搜索一下吧,OK,就第一条结果看看。
看起来跟我得到的错误信息差不多,来仔细瞧一瞧。发现以下一段代码:
/*Check for valid parameter*/
If LEN(@txtBidderID) =0 or ISNULL(@txtBidderID,'') =''
RAISERROR(50002,10, 1,'Error Accessing Bidder Record - Must Provide Bidder ID')
ELSE
作者得到的 Error 50002 应该就是这里输出的啦,那我接下来的工作,就该是找到我这里输出 Error 50010 的那个文件在哪了,找到之后,为啥要给我甩出 Error 50010 就清楚了,如何避免也就迎刃而解了!
可是作者贴出来的是个啥文件,不知道,依次搜索了该文件中的几个关键字后,我 get 到了 trigger 这个概念,大意是说,在执行 insert \ update \ delete 操作之前或是之后,会自动触发一些操作。可这个 trigger 在哪,来找找吧。

查看上图中高亮文件的内容,果然,里面写明了,在什么样的条件下,就会甩出 Error 50002 .
右键该文件,哎,有个 Disable 菜单,看起来是禁用这个 trigger 的意思。
禁用该 trigger 以后,再执行本文最初的 SQL 语句,成功啦!最后再将该 trigger 使能。OK,任务完成!
今天遇到的这个小问题,对于稍懂 SQL 的人来说,应该是非常容易解决的。可是对于我这样对 SQL 知之甚少的人来说,也算得上如临大敌了。现在把解决问题的过程记录下来,一来是给遇到同样问题的其他人提供解决方法,更重要的是提醒自己,遇到问题,重点是要解决问题,不要一遇到某个的问题,就找一堆相关的教程来从头啃,这肯定是不行的,毫无疑问,如此不到半小时就会放弃。始终要把解决当前的问题作为根本目的,一步步来,问题自然就会解决的。
SQL Msg 18054, Level 16, State 1的更多相关文章
- SQL Server ->> Msg 7411, Level 16, State 1, Line 1 -- Server 'XXXX' is not configured for RPC.
关于问题,有两个相关的服务器选项. exec sp_serveroption @server='CIA-SH-SVR-SIS', @optname='rpc', @optvalue='true' ex ...
- Sybase ASE报错:server Error: 8242, Severity: 16, State: 1
昨天上午,同事反映某系统在执行存储过程的过程中报错了,报错的信息异常如下: 05:00000:00009:2014/06/09 15:45:30.34 server Error: 8242, Seve ...
- Natas Wargame Level 16 Writeup(Content-based Blind SQL Injection)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAqwAAADhCAYAAAANm+erAAAABHNCSVQICAgIfAhkiAAAIABJREFUeF
- [译]Stairway to Integration Services Level 16 – Flexible Source Locations (多文件导入)
介绍 在本文中我们将利用SSIS参数,变量 以及 Foreach Loop Container 从多个源动态导入数据. 开始前我们先下载一些数据.WeatherData_Dec08_Apr09.zip ...
- 提高SQL执行效率的16种方法
项目中优化sql语句执行效率的方法:1)尽量选择较小的列2)将where中用的比较频繁的字段建立索引3)select子句中避免使用'*'4)避免在索引列上使用计算.not in 和<> ...
- 【Teradata】安装SQL Assistant和Administrator 16.20(含查看.net版本)
1.安装介质获取: 获取的路径:connections==>Gateways==>Customer Services==>TOOLS & APPLICATIONS(点击Mor ...
- 【SQL必知必会笔记(1)】数据库基础、SQL、MySQL8.0.16下数据库、表的创建及数据插入
文章目录 1.数据库基础 1.1 数据库(database) 1.2 表(table) 1.3 列和数据类型 1.4 行 1.5 主键 2.什么是SQL 3.创建后续练习所需数据库.表(MySQL8. ...
- UNION ALL 视图 'ImprotHIS2012.dbo.ImportHISData' 不可更新,因为没有找到分区依据列。 Severity 16 State 12
-- 3 更正措施,使约束check一次 Alter Table ImprotHIS_Bak_2011.dbo.ImportHISData with check Check Constraint al ...
- SQL 2008 RAISERROR语法在SQL 2012/2014不兼容问题
原文 旧的RAISERROR语法在SQL 2012不兼容问题 raiserror 写法: SQL 2008: raiserror 55030 'text error' SQL 2012: raiser ...
随机推荐
- python—day02_基本数据类型
1,字符串 字符串常用功能: 移除空白 分割 长度 索引 切片 1)移除空白 """S.strip([chars]) -> str Return a copy of ...
- SpringBoot2.x【一】从零开始环境搭建
SpringBoot2.x[一]从零开始环境搭建 对于之前的Spring框架的使用,各种配置文件XML.properties一旦出错之后错误难寻,这也是为什么SpringBoot被推上主流的原因,Sp ...
- (二)vue的生命周期及相关的运行流程
@ 目录 1. vue的生命周期 经过一系列的初始化过程 需要设置数据监听 编译模板 将实例花在到DOM 并在数据变化时更新DOM 等 这是相应的生命周期函数 在用的时候直接写上, 其实很多人都这样, ...
- Spring_api方式实现aop
第一步: public interface UserService { public void add(); public void update(int a); public void delete ...
- Cookie&Sission 部分方法
Cookie:创建Cookie:Cookie cookie = new Cookie(String cookieName,String cookieValue); cookie.setMaxAge(i ...
- MVC案例之通过配置切换底层存储源(面向接口)
1.深入理解面向接口编程: 在类中调用接口的方法,而不必关心具体的实现.这将有利于代码的解耦.使程序有更好的可移植性 和可扩展性 动态修改 Customer 的存储方式:通过修改类路径下的 switc ...
- 面试官:兄弟,说说Java的static关键字吧
读者乙在上一篇我去系列文章里留言说,"我盲猜下一篇标题是,'我去,你竟然不知道 static 关键字'".我只能说乙猜对了一半,像我这么有才华的博主,怎么可能被读者猜中了心思呢,必 ...
- Java实现 蓝桥杯 算法提高 概率计算
算法提高 概率计算 时间限制:1.0s 内存限制:256.0MB 问题描述 生成n个∈[a,b]的随机整数,输出它们的和为x的概率. 输入格式 一行输入四个整数依次为n,a,b,x,用空格分隔. 输出 ...
- Java实现 LeetCode 173 二叉搜索树迭代器
173. 二叉搜索树迭代器 实现一个二叉搜索树迭代器.你将使用二叉搜索树的根节点初始化迭代器. 调用 next() 将返回二叉搜索树中的下一个最小的数. 示例: BSTIterator iterato ...
- Java实现 LeetCode 5 最长回文子串
5. 最长回文子串 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1: 输入: "babad" 输出: "bab&quo ...