mysql如何在存储过程中输出日志信息

 更新时间:2023年11月09日 14:36:18   作者:Bruce小鬼  
这篇文章主要介绍了mysql如何在存储过程中输出日志信息问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql在存储过程中输出日志信息 

直接用select 打印输出

SELECT 'Comment';

用concat连接变量输出

declare myvar INT default 0;
SET myvar = 5;
SELECT concat('myvar is ', myvar);

输出:

myvar is 5

格外创建一个有一列文本列的表,然后往里面塞信息

declare myvar INT default 0;
SET myvar = 5;
insert into tmptable select concat('myvar is ', myvar);

将上面的sql语句封装成一个存储过程log,以后要用的话就直接调用下面的语句就可以了

CALL log(concat('the value is', myvar));

直接输出到一个文本里面

select "penguin" as log into outfile '/tmp/result.txt';

这个命令会有严格的限制,只能将输出文本放在本地,然后给予其创建和写的权限 

一旦输出了一个文本,无法重写,这样可以阻止恶意执行sql注入

mysql存储过程中错误日志记录实现

根据官方提供的信息,及查阅多个博客综合,且自己在环境中试验并验证方案可行。

接下来进入正题,我会尽力写的更通俗易懂一些。

第一步

建一张日志表,具体字段可以根据需求来设计,下图是我的参考

以上字段按顺序分别是ID,存储过程名称,错误代码,错误描述,插入时间,间隔时间。

第二步

在存储过程中添加以上字段的变量

-- 日志记录参数
    DECLARE v_id VARCHAR(50);-- 日志表ID
    DECLARE v_name VARCHAR(50) DEFAULT 'PROC_IMPORTNEWCONTRACT_REAL'; -- 过程名称
    DECLARE v_code VARCHAR(10) DEFAULT '00000';-- 错误码
    DECLARE v_msg_text TEXT DEFAULT 'SUCCESS';-- 返回消息默认为SUCCESS
    DECLARE v_date DATETIME DEFAULT NOW();-- 插入时间默认当前时间
    DECLARE v_invatime DATETIME DEFAULT NOW();-- 间隔时间默认当前时间

以上代码是放在BEGIN下面的

最后一步、事务提交与日志记录

 

以上代码是放在BEGIN   END的END前面的,其中间的逻辑代码无需改变,如果你有特殊需求可以再改造。

参考资料:

上述的CONTINUE意思为sql发生异常时,为保证存储过程继续往下执行,执行ROLLBACK,进而执行日志记录的操作。

如果将CONTINUE改为EXIT,则意为产生异常时,该存储过程会退出,无法执行日志记录的操作,因为该存储过程直接退出了。

RETURNED_SQLSTATE,返回报错代码,MESSAGE_TEXT返回报错具体信息,官方提供的信息里面是上面的写法。 

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL字符串截取指定字符串right使用示例

    MySQL字符串截取指定字符串right使用示例

    这篇文章主要为大家啊AI介绍了MySQL字符串截取指定字符串right使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • SQL语法CONSTRAINT约束操作详情

    SQL语法CONSTRAINT约束操作详情

    这篇文章主要介绍了SQL语法CONSTRAINT约束操作详情,CONSTRAINT,约束,即对数据库表中的数据进行约束,以保证数据记录的完整性和有效性。下面来看看文章的学习介绍吧
    2022-01-01
  • 详解如何利用Xtrabackup进行mysql增量备份

    详解如何利用Xtrabackup进行mysql增量备份

    这篇文章主要为大家介绍了如何利用Xtrabackup进行mysql增量备份详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • SQL实现LeetCode(176.第二高薪水)

    SQL实现LeetCode(176.第二高薪水)

    这篇文章主要介绍了SQL实现LeetCode(176.第二高薪水),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • MySQL的加密解密的几种方式(小结)

    MySQL的加密解密的几种方式(小结)

    这篇文章主要介绍了MySQL的加密解密的几种方式(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • MySQL的Redo Log数据恢复核心机制面试精讲

    MySQL的Redo Log数据恢复核心机制面试精讲

    这篇文章主要为大家介绍了MySQL的Redo Log数据恢复核心机制面试精讲,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • MySQL实现行列转换

    MySQL实现行列转换

    这篇文章介绍了MySQL实现行列转换的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • Innodb存储引擎中的后台线程详解

    Innodb存储引擎中的后台线程详解

    后台线程的主要作用是负责刷新内存池中的数据,保证缓存中的内存缓存的是最近的数据,下面这篇文章主要给大家介绍了关于Innodb存储引擎中后台线程的相关资料,需要的朋友可以参考下
    2022-04-04
  • MySQL创建高性能索引的全步骤

    MySQL创建高性能索引的全步骤

    这篇文章主要给大家介绍了关于MySQL创建高性能索引的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • MySQL视图原理与基本操作示例

    MySQL视图原理与基本操作示例

    这篇文章主要介绍了MySQL视图原理与基本操作,简单描述了mysql视图的概念、功能并结合实例形式分析了mysql视图的创建、查询、修改、删除等相关操作技巧,需要的朋友可以参考下
    2018-03-03

最新评论