今天接到一个看起来很简单的任务--修改数据库中的一项数据。听起来很简单吧。

在网上搜索了一下,很快就拼凑出了相应的 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的更多相关文章

  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 ...

  2. Sybase ASE报错:server Error: 8242, Severity: 16, State: 1

    昨天上午,同事反映某系统在执行存储过程的过程中报错了,报错的信息异常如下: 05:00000:00009:2014/06/09 15:45:30.34 server Error: 8242, Seve ...

  3. Natas Wargame Level 16 Writeup(Content-based Blind SQL Injection)

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAqwAAADhCAYAAAANm+erAAAABHNCSVQICAgIfAhkiAAAIABJREFUeF

  4. [译]Stairway to Integration Services Level 16 – Flexible Source Locations (多文件导入)

    介绍 在本文中我们将利用SSIS参数,变量 以及 Foreach Loop Container 从多个源动态导入数据. 开始前我们先下载一些数据.WeatherData_Dec08_Apr09.zip ...

  5. 提高SQL执行效率的16种方法

      项目中优化sql语句执行效率的方法:1)尽量选择较小的列2)将where中用的比较频繁的字段建立索引3)select子句中避免使用'*'4)避免在索引列上使用计算.not in 和<> ...

  6. 【Teradata】安装SQL Assistant和Administrator 16.20(含查看.net版本)

    1.安装介质获取: 获取的路径:connections==>Gateways==>Customer Services==>TOOLS & APPLICATIONS(点击Mor ...

  7. 【SQL必知必会笔记(1)】数据库基础、SQL、MySQL8.0.16下数据库、表的创建及数据插入

    文章目录 1.数据库基础 1.1 数据库(database) 1.2 表(table) 1.3 列和数据类型 1.4 行 1.5 主键 2.什么是SQL 3.创建后续练习所需数据库.表(MySQL8. ...

  8. UNION ALL 视图 'ImprotHIS2012.dbo.ImportHISData' 不可更新,因为没有找到分区依据列。 Severity 16 State 12

    -- 3 更正措施,使约束check一次 Alter Table ImprotHIS_Bak_2011.dbo.ImportHISData with check Check Constraint al ...

  9. SQL 2008 RAISERROR语法在SQL 2012/2014不兼容问题

    原文 旧的RAISERROR语法在SQL 2012不兼容问题 raiserror 写法: SQL 2008: raiserror 55030 'text error' SQL 2012: raiser ...

随机推荐

  1. MYSQL 中binlog 参数的记录

    http://dev.mysql.com/doc/refman/5.7/en/replication-options-binary-log.html binlog_cache_size Command ...

  2. create-react-app ios8系统中页面空白/样式错乱问题

    1. 空白问题 因为缺少polyfill 在public/index.html 中引入如下js <script src="https://cdnjs.cloudflare.com/aj ...

  3. SpringBoot代码生成器,从此不用手撸代码

    前言 通常在开始开发项目的时候,首先会建立好数据库相关表,然后根据表结构生成 Controller.Service.DAO.Model以及一些前端页面. 如果开发前没有强制的约束,而每个程序员都有自己 ...

  4. Spring全家桶一一SpringBoot与Mybatis

    Spring全家桶系列一一SpringBoot与Mybatis结合 本文授权"Java知音"独家发布. Mybatis 是一个持久层ORM框架,负责Java与数据库数据交互,也可以 ...

  5. js生成一个上限跟下限的随机数

    function sj() { //x上限,y下限 var x = 2000; var y = 1800; var rand = parseInt(Math.random() * (x - y + 1 ...

  6. pycharm安装Numba失败问题

    相关环境变量: pycharm Python 3.8 pip 19.3.1 Numba各个版本都不行 报错内容: Looking in indexes: https://pypi.tuna.tsing ...

  7. Map,HashMap五种遍历方法

    假设有数组            HashMap<Integer, String> h=new HashMap<Integer,String>();        h.put( ...

  8. Kivy中ActionBar控件的使用

    这个控件可以作为导航栏来使用,效果非常好. 1. ActionBar包含的组件 ActionBar中需要一个ActionView作为容器来存放其他控件,比如:ActionPrevious.Action ...

  9. Qt版本中国象棋开发(一)

    开发目的:实现象棋人机对战简单AI,网络对战,移植到android中. 开发平台:windows10 + Qt5.4 for android 开发语言:C++ 开发过程:1.棋盘绘制: 方法一:重写  ...

  10. 前端星计划笔记-day1

    前端 功能,美观,安全,无障碍,性能,兼容,体验 前端编程思想 WA doctype: 文档版本 浏览器决定渲染模式 语义化: 所有的标签都有自己的含义,属性 可读性 前端规范 whatwg css显 ...