MySQL在读取异常错误缓冲区方面的提升方法有哪些

网友投稿 358 2023-12-12

MySQL在读取异常错误缓冲区方面的提升方法有哪些

这篇文章主要介绍MySQL在读取异常错误缓冲区方面的提升方法有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

MySQL在读取异常错误缓冲区方面的提升方法有哪些

先来解释下什么是错误缓冲区?

在MySQL里面, 错误缓冲区只记录最近一次出现的错误, 只要是有新的错误产生,旧的就会被覆盖掉。 所以想知道产生了什么错误, 

就得在每个有可能发生错误的语句后面紧跟着"show warnings" 或者 "show errors"。 最简单的方法是把输出的结果重定向到自己定义的

日志文件里面,这样就可以方便后续查看。当然如果想随时查看这些错误,我们就得通过MySQL提供的API来实现。

自从MySQL 5.6 这个革命性的版本出现后,问题得到了初步解决。虽然离我们想的还差好多。

MySQL 5.6 提供了 get diagnostic 语句来获取错误缓冲区的内容,然后把这些内容输出到不同范围域的变量里,以便我们后续灵活操作。

下来,我们就来看一个例子。

  www.2cto.com  

针对的表结构为:

[sql] 

CREATE TABLE `t_datetime` (  

`id` int(11) NOT NULL,

  `log_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,  

`end_time` datetime NOT NULL,

  PRIMARY KEY (`id`)  

) ENGINE=InnoDB DEFAULT CHARSET=utf8  

存储过程代码为:

[sql] 

DELIMITER $$  

www.2cto.com

USE `new_t`$$  

DROP PROCEDURE IF EXISTS `sp_do_update`$$  

CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_do_update`(

    IN f_id INT,  

    IN f_log_time VARCHAR(255),  

    IN f_end_time VARCHAR(255)  

    )  

BEGIN  

DECLARE i_con1 TINYINT DEFAULT 0;

      DECLARE i_code CHAR(5) DEFAULT 00000;  

      DECLARE i_msg TEXT;  

DECLARE i_rows INT;

      DECLARE i_con1 CONDITION FOR 1048; -- 这个错误代码代表字段限制不能NULL。  

      DECLARE CONTINUE HANDLER FOR i_con1  

BEGIN

        SET i_con1 = 1;  

        get diagnostics CONDITION 1  

          i_code = returned_sqlstate, i_msg = message_text;  

END;    www.2cto.com

      UPDATE t_datetime   

      SET log_time = IFNULL(f_log_time,NULL),   

end_time = IFNULL(f_end_time,NULL)

      WHERE id = f_id;  

      IF i_con1 = 0 THEN  

        get diagnostics i_rows = ROW_COUNT;  

SET @i_result = CONCAT("Update succeeded, affected ", i_rows,.);

      ELSE  

SET @i_result = CONCAT(Update failed, error code is 1042, related message is ,i_msg,.);

      END IF;  

      SELECT @i_result;  

    END$$  

DELIMITER ;  

我们来执行上面的存储过程,完了后,就能把错误信息保存到SESSION 变量@i_result 中。这样,方便了后期进行各种输出。  www.2cto.com

[sql] 

CALL sp_do_update(1,NOW(),DATE_ADD(NOW(),INTERVAL 1 DAY));

Result.  

Update succeeded, affected 1.  

CALL sp_do_update(1,NULL,NULL);  

Result.  

Update failed, error code is 1042, related message is Column log_time cannot be null.

以上是“MySQL在读取异常错误缓冲区方面的提升方法有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:为什么数据库索引多用B+树
下一篇:Exchange Partition的示例分析
相关文章

 发表评论

暂时没有评论,来抢沙发吧~