首页
学习
活动
专区
工具
TVP
发布

如何找到抛出ORA-00933错误的SQL

blog.csdn.net/bisal/article/details/103137639 前几天上线,凌晨3点多打车回来的路上,兄弟联系我,提了一个问题,某核心系统,上线的时候,报了很多ORA-00933的错误...,明显是应用写的SQL出现了错误导致的,但是因为未将出错的SQL打印到日志中,所以不知道究竟是什么SQL出错了,由于逻辑中涉及到很多的SQL,逐个排查,非常耗时。...ORA-00933,意思是“SQL command not properly ended”,明显是SQL的语法出现错误,但是现在的问题,就是如何找到错误的SQL?...我们执行如下这两条SQL,第一条是错误的,提示ORA-00933,第二条是正确的, SQL> select object_id from t whereobject_id=1; select object_id...其中一项,就是应用执行错误的SQL语句需要打印到应用日志中,包括SQL原文、报错信息、参数等,一方面为监控报警提供数据,另一方面便于问题的排查。

2.4K30
您找到你想要的搜索结果了吗?
是的
没有找到

Python学习 Day 11 错误处理 try 调用堆栈 记录错误 抛出错误

抛出错误 因为错误是class,捕获一个错误就是捕获到该class的一个实例。因此,错误并不是凭空产生的,而是有意创建并抛出的。...Python的内置函数会抛出很多类型的错误,我们自己编写的函数也可以抛出错误。...如果要抛出错误,首先根据需要,可以定义一个错误的class,选择好继承关系,然后,用raise语句抛出一个错误的实例: # err.py class FooError(StandardError):...raise def main(): bar('0') main() 在bar()函数中,我们明明已经捕获了错误,但是,打印一个Error!后,又把错误通过raise语句抛出去了,这不有病么?...raise语句如果不带参数,就会把当前错误原样抛出

97320

窥探Swift编程之错误处理与异常抛出

今天博客的主题就是系统的搞一下Swift中的错误处理,以及看一下Swift中是如何抛出异常的。在编译型语言中,错误一般分为编译错误和运行时错误。...在今天的博客中,先给出主动产生异常的几种情况,然后再给出如何处理被动异常。...下方函数就是一个可以抛出错误的函数,抛出错误就是我们在上面枚举中所定义的类型。...也就是说,我们可以在抛出错误时,给自定义错误类型提供错误原因。该功能在开发中是非常常用的,而且用起来也是非常爽的。接下来就看一下如何为我们的错误类型添加错误原因。...三、在错误处理中使用内置关键字 1.初探这些内置关键字 在Swift中提供了一些内置关键字(__FILE__, __FUNCTION__, __LINE__等)来获取上下文信息,在本篇博客的第三部分,将会给出如何在我们的错误处理中使用这些内置关键字

2.1K50

编写可维护代码3:适当的抛出错误提示

js开发中,调试错误是一个比较头疼的事,又不像java的debug那么方便,定位错误往往不是那么容易,除非对代码熟悉无比,但即使是自己写的代码,功能一复杂,时间一长,再想快速定位问题,至少我现在是比较头疼的...js抛出错误的方法有两种:throw new Error()抛出错误和try...catch..捕获错误。...当以这种方式抛出错误时,如果没有经try-catch语句来捕获的话,浏览器通常直接在控制台显示错误消息字符串。 通常在抛出错误提示字符串中,应尽量写清错误目标和原因。...那什么时候需要抛出错误呢? 修复一个自认为较复杂的错误后,及时增加相应的自定义错误提示。 写代码时,思考不想要发生的程序时,针对这个不想要发生的事,抛出错误提示。...Error:所有错误的基本类型,实际上引擎从不会抛出该类型的错误 EvalError:通过eval()函数执行代码发生错误抛出 RangerError:一个数字超出它的边界时抛出,比较罕见 ReferenceError

98450

【C++】异常处理 ④ ( 异常接口声明 | 异常接口语法 | 抛出一种类型的异常 | 抛出多种类型的异常 | 抛出任意类型的异常 | 不能抛出异常 | 抛出异常类型错误 | 代码示例 )

: 函数返回值 函数名(函数参数列表) throw (异常类型1, 异常类型2, ..., 异常类型n) 3、抛出一种类型的异常 抛出一种类型的异常 : 在 void fun() 函数中 , 可能会抛出...在 函数 中 抛出异常 // 异常接口 : 只允许抛出 char 类型异常 void fun() throw(char) { cout << "开始抛出 char 类型 异常 " << endl;...cout << "开始抛出 char 类型 异常 " << endl; // 抛出一个 char 类型的异常 throw 'A'; } 6、不能抛出任何类型异常 - 声明 throw() 如果禁止函数抛出异常...在 函数 中 抛出异常 // 异常接口 : 不允许抛出异常 void fun() throw() { cout << "开始抛出 char 类型 异常 " << endl; // 抛出一个 char...========== 生成: 成功 1 个,失败 0 个,最新 0 个,跳过 0 个 ========== 执行结果 : 7、抛出异常类型错误 抛出异常类型错误 : 如果一个函数抛出了它的异常接口声明所不允许抛出的异常

22710

WPF 如何跨线程重新抛出异常

有一些代码是在框架层写的,这部分代码不应该在后台线程抛出异常,如何将后台线程的异常在主线程抛出,同时不会带上主线程的堆栈可以保留异常的全部信息 在 .NET 提供了 ExceptionDispatchInfo...类,可以用于捕获某个异常,然后使用提供的抛出方法重新抛出 可以用在某个地方统一收集异常,然后统一抛出,此时抛出的异常的堆栈和信息都不会改变,会比下面的方法更好 public static...ReThrowException(Exception exception) { throw exception; } 上面代码使用 throw 在另一个函数抛出...KicaicicayiJearjelrelur.MainWindow.NalbibechaLuhaqayna() at KicaicicayiJearjelrelur.MainWindow..ctor() 如果是在后台线程框架抛出的...}); } 代码放在 github 欢迎下载 在 WPF 框架我使用这个方法提了建议,在触摸线程的异常抛到主线程 详细请看 使用 ExceptionDispatchInfo 捕捉并重新抛出异常

38420

WPF 如何跨线程重新抛出异常

有一些代码是在框架层写的,这部分代码不应该在后台线程抛出异常,如何将后台线程的异常在主线程抛出,同时不会带上主线程的堆栈可以保留异常的全部信息 在 .NET 提供了 ExceptionDispatchInfo...类,可以用于捕获某个异常,然后使用提供的抛出方法重新抛出 可以用在某个地方统一收集异常,然后统一抛出,此时抛出的异常的堆栈和信息都不会改变,会比下面的方法更好 public static...ReThrowException(Exception exception) { throw exception; } 上面代码使用 throw 在另一个函数抛出...KicaicicayiJearjelrelur.MainWindow.NalbibechaLuhaqayna() at KicaicicayiJearjelrelur.MainWindow..ctor() 如果是在后台线程框架抛出的...ExceptionDispatchInfo.Capture(exception).Throw(); }); } 代码放在 github 欢迎下载 详细请看 使用 ExceptionDispatchInfo 捕捉并重新抛出异常

83810

Java 如何抛出异常、自定义异常

2、throw : 将产生的异常抛出(强调的是动作),抛出的既可以是异常的引用,也可以是异常对象。...注意 : 调用可能会抛出异常的方法,必须添加try-catch代码块尝试去捕获异常 或者 添加throws 声明 来将异常 抛出给更上一层的调用者进行处理,这里需要注意一个细节:新的异常包含原始异常的所有信息...4、throw 用户抛出异常,当在当前方法中抛出异常后,当前方法执行结束(throw 后,如果有finally语句的话,会执行到finally语句后再结束。)。可以理解成return一样。...重写父类Exception的方法,那么如何查看Exception具有哪些API,快捷键:选中Exception, command+单击。...包装成 RuntimeException 异常继续抛出,但是test2()方法却没有声明 抛出异常 ?

2.3K10
领券