当前位置:  开发笔记 > 编程语言 > 正文

我可以使用PHP检测和处理MySQL警告吗?

如何解决《我可以使用PHP检测和处理MySQL警告吗?》经验,为你挑选了1个好方法。

我正在处理一个MySQL表,它将JobName列定义为UNIQUE.如果有人试图使用数据库中已有的JobName将新作业保存到数据库,MySQL会发出警告.

我希望能够在我的PHP脚本中检测到这个警告,就像错误一样,并适当地处理它.理想情况下,我想知道MySQL抛出了什么样的警告,以便我可以分支代码来处理它.

这可能吗?如果没有,是因为MySQL没有这种能力,PHP没有这种能力,或两者兼而有之?



1> Ian..:

要警告本地"标记"到PHP本身需要更改mysql/mysqli驱动程序,这显然超出了这个问题的范围.相反,您将不得不基本上检查您在数据库上进行的每个查询以获取警告:

$warningCountResult = mysql_query("SELECT @@warning_count");
if ($warningCountResult) {
    $warningCount = mysql_fetch_row($warningCountResult );
    if ($warningCount[0] > 0) {
        //Have warnings
        $warningDetailResult = mysql_query("SHOW WARNINGS");
        if ($warningDetailResult ) {
            while ($warning = mysql_fetch_assoc($warningDetailResult) {
                //Process it
            }
        }
    }//Else no warnings
}

显然,应用en-mass会非常昂贵,因此您可能需要仔细考虑警告何时以及如何出现(这可能会导致您重构以消除它们).

作为参考,MySQL SHOW WARNINGS

当然,你可以省去初始查询SELECT @@warning_count,这可以为你保存每次执行的查询,但我把它包含在迂腐的完整性中.

推荐阅读
我我檬檬我我186
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有