为啥这个 sybase 错误会随着查询的任何更改而消失?

Posted

技术标签:

【中文标题】为啥这个 sybase 错误会随着查询的任何更改而消失?【英文标题】:Why does this sybase error go away with any change to the query?为什么这个 sybase 错误会随着查询的任何更改而消失? 【发布时间】:2015-03-30 05:28:34 【问题描述】:

我多年来一直使用的查询突然开始抛出一个奇怪的错误。当我对查询进行外观更改(1+x 而不是 x+1)时,错误不再发生。它抱怨的存储过程甚至不再存在于服务器上!

我很好奇是否有人对问题是什么以及为什么此“更改”可以解决问题有任何想法?

之前的查询:

UPDATE SOME_DB..JOB_QUEUE
SET ERROR_COUNT = ERROR_COUNT + 1,
    JOB_START_TIME = '1'
WHERE JOB_ID = 0

之后的查询:

UPDATE SOME_DB..JOB_QUEUE
SET ERROR_COUNT = 1 + ERROR_COUNT,
    JOB_START_TIME = '1'
WHERE JOB_ID = 0

它抛出的错误:

Sybase.Data.AseClient.AseException: Procedure sp_net_dblatency expects parameter @heartbeat, which was not supplied.

我想知道是否有人知道这里发生了什么?

编辑。 这是存储的过程。

create procedure sp_net_dblatency
    @heartbeat datetime
as
    update DATABASE_1234..LATENCY set START_UTC_TIME=@heartbeat, END_UTC_TIME=getutcdate() where DATABASE_NAME=db_name()
    if (@@ROWCOUNT = 0)
        insert DATABASE_1234..LATENCY (DATABASE_NAME, START_UTC_TIME, END_UTC_TIME) values (db_name(), @heartbeat, getutcdate())

【问题讨论】:

也许你的 sp 被黑了并且在代码中插入了一个 @hearbeat 参数。您的简单修复导致它被重新编译。 sp 曾经存在,@heartbeat 是一个参数。但是sp已经在几个月前被删除了。 是否所有与 sp_netiq_dblatency 相关的同义词也都被删除了? 我对整个数据库进行了文本搜索(使用 qwerybuilder 的搜索实用程序),但我没有使用 proc 找到任何内容。 如果您使用的是 C#(我假设是 Visual Studio),您是否检查过您没有在 Visual Studio 中保存与数据库不同步的本地版本的数据库?如果有本地版本,请运行架构比较以确保它是最新的。 【参考方案1】:

Sybase 的优化器可能缓存了错误地引用已删除过程的计划。它关注历史并缓存各种统计数据,并根据大量缓存信息生成计划。有时,我发现它会开始在非常大的查询上生成非常糟糕的计划。我遇到过几次,并将其作为错误报告给 Sybase,但他们无法重现它(我也无法可靠地重现它)。

解决方法是稍微更改查询或添加计划语句以覆盖错误计划。带有 PLAN 语句的查询将使用提供的计划而不是生成计划。希望对您有所帮助。

【讨论】:

以上是关于为啥这个 sybase 错误会随着查询的任何更改而消失?的主要内容,如果未能解决你的问题,请参考以下文章

为啥我的 pyqt 信号错误会冻结 ui,直到调用另一个 python 函数

为啥密码错误会导致“填充无效,无法删除”?

为啥 PHP 错误会打印两次?

Hibernate + Sybase Iq

为啥我的linux系统不能打密码?

redux-observable 无法从发出的动作中捕获错误,错误会停止动作流