[发明专利]日志插入方法、装置、计算机装置及存储介质有效
申请号: | 201910727085.6 | 申请日: | 2019-08-07 |
公开(公告)号: | CN110633258B | 公开(公告)日: | 2022-08-12 |
发明(设计)人: | 李斌 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
主分类号: | G06F16/18 | 分类号: | G06F16/18;G06F16/13 |
代理公司: | 深圳市赛恩倍吉知识产权代理有限公司 44334 | 代理人: | 陈敬华;刘丽华 |
地址: | 518000 广东省深圳市福田区福*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 日志 插入 方法 装置 计算机 存储 介质 | ||
本发明提供一种日志插入方法及相关设备。所述方法包括:设定任务配置文件;读取任务配置文件中的第一命令注释语句;根据第一命令注释语句的命令标识和命令参数初始化任务配置文件对应的全局变量组;读取任务配置文件中的第二命令注释语句,解析第二命令注释语句的命令标识和命令参数,根据第二命令注释语句的命令标识判断第二命令注释语句的类别;若第二命令注释语句的类别为插入命令注释语句,通过全局变量组将插入命令注释语句的命令参数插入日志表;读取任务配置文件中第二命令注释语句对应的SQL语句,执行SQL语句;若SQL语句执行失败,通过全局变量组将执行错误信息插入日志表。本发明能够提升将SQL语句执行错误信息插入日志表的效率。
技术领域
本发明涉及日志技术领域,具体涉及一种日志插入方法、装置、计算机装置及计算机存储介质。
背景技术
普通SQL脚本文件以及存储过程,如果要插入日志表。需要手工写相应插入语句,增加开发复杂度。在数据库开发过程中,经常出现SQL语句执行失败的情况。为了记录SQL语句执行失败的日志信息,开发人员需要在SQL脚本文件或存储过程中插入报错语句,从而产生了额外的工作量,增加了开发复杂度。因此,需要一种能够简单高效地记录SQL语句执行失败的日志信息的方法。
发明内容
鉴于以上内容,有必要提出一种日志插入方法、装置、计算机装置及计算机存储介质,其可以提升将SQL语句执行错误信息插入日志表的效率。
本申请的第一方面提供一种日志插入方法,所述方法包括:
设定任务配置文件,所述任务配置文件包括第一命令注释语句,第二命令注释语句和与所述第二命令注释语句对应的SQL语句;
读取所述第一命令注释语句,解析所述第一命令注释语句的命令标识和命令参数;
根据所述第一命令注释语句的命令标识和命令参数初始化所述任务配置文件对应的全局变量组;
读取所述第二命令注释语句,解析所述第二命令注释语句的命令标识和命令参数,根据所述第二命令注释语句的命令标识判断所述第二命令注释语句的类别;
若所述第二命令注释语句的类别为插入命令注释语句,通过所述全局变量组将所述插入命令注释语句的命令参数插入日志表,所述插入命令注释语句的命令参数包括与所述插入命令注释语句对应的SQL语句的日志信息;
读取所述第二命令注释语句对应的SQL语句,执行所述SQL语句;
若所述SQL语句执行失败,生成所述SQL语句的执行错误信息,将所述SQL语句的执行错误信息赋值给所述全局变量组中所述执行错误信息对应的全局变量,通过所述全局变量组将所述执行错误信息插入所述日志表。
另一种可能的实现方式中,所述根据所述第一命令注释语句的命令标识和命令参数初始化所述任务配置文件对应的全局变量组包括:
将所述全局变量组中的全局变量初始化为空值;
查询预设的命令标识-全局变量表,判断所述全局变量组中是否包含所述第一命令注释语句的命令标识对应的全局变量;
若所述全局变量组中包含所述第一命令注释语句的命令标识对应的全局变量,则将所述第一命令注释语句的命令标识对应的命令参数赋值给所述全局变量组中所述第一命令注释语句的命令标识对应的全局变量。
另一种可能的实现方式中,所述通过所述全局变量组将所述插入命令注释语句的命令参数插入日志表包括:
查询预设的命令标识-全局变量表,确定所述全局变量组中所述插入命令注释语句的命令标识对应的全局变量;
将所述插入命令注释语句的命令参数赋值给所述全局变量组中所述插入命令注释语句的命令标识对应的全局变量;
根据所述全局变量组生成第一日志插入语句;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910727085.6/2.html,转载请声明来源钻瓜专利网。