CN110851346B - 查询语句边界问题的检测方法、装置、设备及存储介质 - Google Patents
查询语句边界问题的检测方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN110851346B CN110851346B CN201910902759.1A CN201910902759A CN110851346B CN 110851346 B CN110851346 B CN 110851346B CN 201910902759 A CN201910902759 A CN 201910902759A CN 110851346 B CN110851346 B CN 110851346B
- Authority
- CN
- China
- Prior art keywords
- sql
- boundary
- statement
- file
- boundary problem
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000001514 detection method Methods 0.000 title claims abstract description 48
- 238000000034 method Methods 0.000 claims abstract description 54
- 238000012216 screening Methods 0.000 claims abstract description 21
- 230000002159 abnormal effect Effects 0.000 claims description 20
- 230000014509 gene expression Effects 0.000 claims description 12
- 238000004590 computer program Methods 0.000 claims description 7
- 238000000605 extraction Methods 0.000 claims description 4
- 238000011161 development Methods 0.000 abstract description 7
- 238000004891 communication Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 3
- 238000012545 processing Methods 0.000 description 3
- 238000004364 calculation method Methods 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 230000010365 information processing Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 238000012552 review Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/362—Software debugging
- G06F11/366—Software debugging using diagnostics
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/242—Query formulation
- G06F16/2433—Query languages
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Mathematical Physics (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请实施例公开了一种查询语句边界问题的检测方法、装置、设备及存储介质,涉及数据库语句检测技术领域。该方法包括:接收包含指定的文件存储路径sql边界检测指令;筛选出文件存储路径下的所有sql文件;提取sql文件中的所有sql语句,从sql语句中提取出包含in操作符的sql条件语句;检测sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题;生成用于提示边界问题的推送内容发送至目标用户。所述方法通过合理的步骤对sql文件的内容进行针对性分析,判断出sql文件中的sql语句是否存在因in操作符引起的边界问题,从而方便开发人员了解sql文件中的边界问题并对问题进行定位,提高了开发的质量和对边界问题的处理时效。
Description
技术领域
本申请实施例涉及数据库语句检测技术领域,特别是一种查询语句边界问题的检测方法、装置、设备及存储介质。
背景技术
开发人员在进行数据库的SQL(Structured Query Language,结构化查询语言)开发过程中,有时需要查询两种状态的值,如果用普通的查询,需要查两次,然后把两次查询的值放到一个集合中,再去重,这样查询的方式非常麻烦,而使用SQL中的in条件查询则会方便不少。
但使用in条件查询时,如果查询的对象传入的是静态数据,则其最大的接收量受到由一定数值表示的边界值的限制,一旦超过该边界值,便会产生边界问题。而使用in条件时往往容易忽略其使用时易出现的边界问题,导致程序功能异常,无法正常使用。因此在对编写完的代码文件进行复查时,开发人员希望能对于in条件的边界问题进行自动检测,判断使用了in条件的sql语句中是否存在边界问题。
发明内容
本申请实施例所要解决的技术问题是,提供一种查询语句边界问题的检测方法、装置、设备及存储介质,对sql语句中in条件的边界问题进行检测,判断是否存在边界问题。
为了解决上述技术问题,本申请实施例所述的一种查询语句边界问题的检测方法,采用了如下所述的技术方案:
一种查询语句边界问题的检测方法,包括:
接收sql边界检测指令,所述sql边界检测指令中包含指定的文件存储路径;
响应于所述sql边界检测指令,筛选出所述文件存储路径下的所有sql文件;
提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句;
检测所述sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成相应的判断结果;
基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户。
本申请实施例所述的查询语句边界问题的检测方法,通过合理的步骤对sql文件的内容进行针对性分析,判断出sql文件中的sql语句是否存在因in操作符引起的边界问题,从而方便开发人员了解sql文件中的边界问题并对问题进行定位,提高了开发的质量和对边界问题的处理时效。
进一步的,所述的查询语句边界问题的检测方法,所述筛选出所述文件存储路径下的所有sql文件的步骤包括:
检测所述文件存储路径下的第一级目录中的所有文件,筛选出其中的sql文件;
逐级访问所述第一级目录下的所有文件夹,直至对所述第一级目录下的所有文件夹中的文件完成检测,筛选出其中的所有sql文件。
进一步的,所述的查询语句边界问题的检测方法,所述提取所述sql文件中的所有sql语句的步骤包括:
调用dom4j解析包或mybatis框架;
通过dom4j或mybatis提供的API对所述sql文件执行解析,提取出所述sql文件中的所有sql语句。
进一步的,所述的查询语句边界问题的检测方法,所述从所述sql语句中提取出包含in操作符的sql条件语句的步骤包括:
配置正则表达式;
基于所述正则表达式匹配所述sql语句中包含in操作符的sql条件语句,并提取出匹配到的所述sql条件语句。
进一步的,所述的查询语句边界问题的检测方法,所述提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句的步骤之后,所述方法还包括步骤:
解析所述sql条件语句,获取每条sql条件语句对应的id;
根据所述id在所述sql语句中递归查询,以获取与所述sql条件语句匹配的类和行数。
进一步的,所述的查询语句边界问题的检测方法,所述基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户的步骤包括:
当判断存在所述参数数量大于边界阈值的边界问题时,将对应的存在边界问题的sql条件语句记为异常条件语句;
将所述异常条件语句及获取的与所述异常条件语句匹配的类和行数共同纳入所述推送内容。
进一步的,所述的查询语句边界问题的检测方法,所述检测所述sql条件语句中每个in操作符对应的参数数量的步骤之后,所述方法还包括步骤:
统计in操作符的总数量a,以及参数数量未超过预设的性能边界阈值x的in操作符的数量b,计算条件比例的值a/b;
所述基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户的步骤包括:
基于所述条件比例的值生成提示消息发送至目标用户,以向目标用户提示所述文件存储路径下sql的查询效率。
为了解决上述技术问题,本申请实施例还提供一种查询语句边界问题的检测装置,采用了如下所述的技术方案:
一种查询语句边界问题的检测装置,包括:
指令接收模块,用于接收sql边界检测指令,所述sql边界检测指令中包含指定的文件存储路径;
指令执行模块,用于响应于所述sql边界检测指令,筛选出所述文件存储路径下的所有sql文件;
语句提取模块,用于提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句;
问题判断模块,用于检测所述sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成相应的判断结果;
结果发送模块,用于基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户。
本申请实施例所述的查询语句边界问题的检测装置,通过合理的步骤对sql文件的内容进行针对性分析,判断出sql文件中的sql语句是否存在因in操作符引起的边界问题,从而方便开发人员了解sql文件中的边界问题并对问题进行定位,提高了开发的质量和对边界问题的处理时效。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,采用了如下所述的技术方案:
一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如上述任意一项技术方案所述的查询语句边界问题的检测方法的步骤。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,采用了如下所述的技术方案:
一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如上述任意一项技术方案所述的查询语句边界问题的检测方法的步骤。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例公开了一种查询语句边界问题的检测方法、装置、设备及存储介质,本申请实施例所述的查询语句边界问题的检测方法,接收包含指定的文件存储路径sql边界检测指令后;响应于sql边界检测指令,筛选出文件存储路径下的所有sql文件;提取sql文件中的所有sql语句,并进一步从sql语句中提取出包含in操作符的sql条件语句;检测sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成响应的判断结果;基于判单结果生成用于提示边界问题的推送内容发送至目标用户。所述方法通过合理的步骤对sql文件的内容进行针对性分析,判断出sql文件中的sql语句是否存在因in操作符引起的边界问题,从而方便开发人员了解sql文件中的边界问题并对问题进行定位,提高了开发的质量和对边界问题的处理时效。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例可以应用于其中的示例性***架构图;
图2为本申请实施例中所述查询语句边界问题的检测方法的一个实施例的流程图;
图3为本申请实施例中所述查询语句边界问题的检测装置的一个实施例的结构示意图;
图4为本申请实施例中计算机设备的一个实施例的结构示意图。
具体实施方式
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同。本文中在本申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请。
需要说明的是,本申请的说明书和权利要求书及上述附图中的术语“包括”、“包含”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、***、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其他步骤或单元。在本申请的权利要求书、说明书以及说明书附图中的术语,诸如“第一”和“第二”等之类的关系术语仅仅用来将一个实体/操作/对象与另一个实体/操作/对象区分开来,而不一定要求或者暗示这些实体/操作/对象之间存在任何这种实际的关系或者顺序。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其他实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其他实施例相结合。
为了使本技术领域的人员更好地理解本申请的方案,下面将结合本申请实施例中的相关附图,对本申请实施例中的技术方案进行清楚、完整地描述。
如图1所示,***架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture ExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving PictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的页面提供支持的后台服务器。
需要说明的是,本申请实施例所提供的查询语句边界问题的检测方法一般由服务器/终端设备执行,相应地,查询语句边界问题的检测装置一般设置于服务器/终端设备中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了本申请实施例中所述查询语句边界问题的检测方法的一个实施例的流程图。所述查询语句边界问题的检测方法,包括以下步骤:
步骤201:接收sql边界检测指令,所述sql边界检测指令中包含指定的文件存储路径。
本申请实施例中,开发人员等目标用户需要了解数据库中的sql文件中是否存在关于in条件的边界问题时,其首先需要根据实际需求配置好sql检测指令,然后将sql检测指令发送给服务器以请求对边界问题进行检测。
在配置sql检测指令时,目标用户需要根据其实际需求指定待检测的sql文件所在的存储路径。在本申请实施例中,服务器还能够提供可视化交互界面以供目标用户方便地配置文件存储路径。
在本申请实施例中,所述查询语句边界问题的检测方法运行于其上的电子设备(例如图1所示的服务器/终端设备)可以通过有线连接方式或者无线连接方式接收用户发出的sql边界检测指令。需要指出的是,上述无线连接方式可以包括但不限于3G/4G连接、WiFi连接、蓝牙连接、WiMAX连接、Zigbee连接、UWB(ultra wideband)连接、以及其他现在已知或将来开发的无线连接方式。
步骤202:响应于所述sql边界检测指令,筛选出所述文件存储路径下的所有sql文件。
服务器在接收到所述sql检测指令后,便基于所述sql检测指令所指示的内容,访问所述文件存储路径,并以递归遍历地方式在所述文件存储路径下筛选出所有sql文件。Sql文件指后缀名为sql的数据库脚本文件,sql文件中的内容主要为用于在数据库中执行的sql语句,sql文件可以通过数据库工具打开并在数据库中执行其中的sql语句。
在本申请的一些实施例中,所述步骤202包括:
检测所述文件存储路径下的第一级目录中的所有文件,筛选出其中的sql文件;
逐级访问所述第一级目录下的所有文件夹,直至对所述第一级目录下的所有文件夹中的文件完成检测,筛选出其中的所有sql文件。
在所述文件存储路径下进行文件筛选时,需要检测该文件存储路径下的所有文件及文件夹。而通过在需检测的文件存储路径下,首先筛选出第一级目录下判断为sql文件的对象(又可称为“类”),然后进一步访问所述第一目录的文件夹下的文件和子文件夹,直至对每个文件及子文件夹中的内容逐级进行检测,从而筛选出所述文件存储路径下的所有sql文件。
步骤203:提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句。
基于筛选出的sql文件,通过进一步解析筛选,提取出所有sql文件中的所有sql语句后,在所有sql语句中进行识别判断,确认sql语句中是否包含有in操作符,若识别出了包含in操作符的sql语句,便将对应的sql语句提取出来记为sql条件语句。一般地,每个in操作符对应一条sql条件语句。
在本申请实施例的一种具体实施方式中,步骤203中所述提取所述sql文件中的所有sql语句的步骤包括:
调用dom4j解析包或mybatis框架;
通过dom4j或mybatis提供的API对所述sql文件执行解析,提取出所述sql文件中的所有sql语句。
具体地,Dom4j是一个开源的解析包,可以用于对主流的API(ApplicationProgramming Interface,应用程序编程接口)进行性能、功能和易用性的评测。Mybatis则是一个持久层框架,支持定制化sql,其可以提供用于对sql文件进行解析的api,以获取sql文件的相关信息,如sql文件中的sql语句。
在本申请实施例的一种具体实施方式中,步骤203中所述从所述sql语句中提取出包含in操作符的sql条件语句的步骤包括:
配置正则表达式;
基于所述正则表达式匹配所述sql语句中包含in操作符的sql条件语句,并提取出匹配到的所述sql条件语句。
正则表达式是对字符串操作的一种逻辑公式,是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。
本申请实施例中,在完成配置用于匹配in操作符的正则表达式后,通过所述正则表达式从所有sql语句中筛选出包含in操作符语句的部分,并记为sql条件语句。
步骤204:检测所述sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成相应的判断结果。
在数据库中进行查询时,利用一个in操作符进行查询时的数据数量会受到一定数量范围的限制,该范围的最大值视为边界阈值,一般而言,所述边界阈值的数值为1000,即若查询时的数据数量超过1000,该条查询语句便会报错。以下对sql语句中in操作符的应用进行举例:如在sql语句delete from student where id in(1,2,3.....)中,括号里面字段的个数最多只能为1000个,超过1000个就会导致程序无法正常运行,in操作符对应的参数数量即指括号中字段的个数。
通过检测工具检测每个sql条件语句中in操作符的参数数量,若检测出数量大于边界阈值,则将对应的sql条件语句进行标记,检测完所有的sql条件语句后,进行统计汇总生成判断结果。所述判断结果中包括:是否存在边界问题,以及存在边界问题的sql条件语句的数量等内容。
步骤205:基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户。
所述推送内容能够在服务器的页面上,以列表的形式展示,同时将相关信息通过邮件等方式发送给开发人员,以提醒开发人员复查边界问题和修改代码。
在本提案的一种实施方式中,开发人员获知存在边界问题希望避免边界问题的产生时,可以预先建立用于存储待调用数据的临时表,将in操作符希望调用的数据均***到所述临时表中,在通过in操作符进行查询时,便能访问所述临时表从所述临时表中读取待调用数据。如delete from student where id in(1,2,3.....),当括号中待调用数据的数量为2000时,超过了数值为1000的边界阈值,而将这2000个值写入到一个临时表temp中后,利用以下sql条件语句便能实现正常的调用查询select*from t where id in(select idfrom temp)。
在本申请的一些实施例中,所述步骤203之后,所述查询语句边界问题的检测方法还包括步骤:
解析所述sql条件语句,获取每条sql条件语句对应的id;
根据所述id在所述sql语句中递归查询,以获取与所述sql条件语句匹配的类和行数。
类的实例称为对象,本申请中类即指sql条件语句所在的sql文件,行数则指sql条件语句在sql文件中所处的行数。
通过解析匹配到的sql条件语句,获取每条sql条件语句对应的id(identification,标签),再根据若干个id在sql语句中查询,从而获取到每条sql条件语句所对应的类和行数。如此可以方便目标用户定位到所需查看的sql条件语句的位置,尤其是出现了边界问题的sql条件语句的位置。
在进一步的一种具体实施方式中,所述步骤205包括:
当判断存在所述参数数量大于边界阈值的边界问题时,将对应的存在边界问题的sql条件语句记为异常条件语句;
将所述异常条件语句及获取的与所述异常条件语句匹配的类和行数共同纳入所述推送内容。
使生成的用于提示边界问题的推送内容中,还包括存在边界问题的sql条件语句及其相关信息,并将其发送给开发人员,能够以此方便开发人员定位和分析问题。
在本申请实施例中,纳入所述推送内容的信息还可以包括:所述异常条件语句的代码提交人,所述异常条件语句的id等信息。
在本申请的一些实施例中,步骤204中所述检测所述sql条件语句中每个in操作符对应的参数数量的步骤之后,所述查询语句边界问题的检测方法还包括步骤:
统计in操作符的总数量a,以及参数数量未超过预设的性能边界阈值x的in操作符的数量b,计算条件比例的值a/b。
所述步骤205包括:基于所述条件比例的值生成提示消息发送至目标用户,以向目标用户提示所述文件存储路径下sql的查询效率。
利用in操作符进行查询时,在边界阈值的范围内,其参数值的数量超过一定数值后,查询的性能会急剧下降,其中,将该阈值记为性能边界阈值x,实际应用中所述x的值一般为300。
通过统计和计算a/b的值,可以获知在x范围内的in操作符的条件比例,以此可以在一定程度上判断所述文件存储路径下sql的查询效率。
进一步的,还可以以类似上述步骤中标记异常条件语句并纳入推送内容的方式,获取参数值的数量超过性能边界阈值的sql条件语句,并根据id在sql语句中递归查询获取到对应的sql条件语句的类和行数后,将携带以上信息的推送内容发送至目标用户,以方便目标用户定位分析。
本申请实施例所述的查询语句边界问题的检测方法,通过合理的步骤对sql文件的内容进行针对性分析,判断出sql文件中的sql语句是否存在因in操作符引起的边界问题,从而方便开发人员了解sql文件中的边界问题并对问题进行定位,提高了开发的质量和对边界问题的处理时效。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,该计算机程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
进一步参考图3,图3示出了为本申请实施例中所述查询语句边界问题的检测装置的一个实施例的结构示意图。作为对上述图2所示方法的实现,本申请提供了一种查询语句边界问题的检测装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图3所示,本实施例所述的查询语句边界问题的检测装置包括:
指令接收模块301;用于接收sql边界检测指令,所述sql边界检测指令中包含指定的文件存储路径。
指令执行模块302;用于响应于所述sql边界检测指令,筛选出所述文件存储路径下的所有sql文件。
语句提取模块303;用于提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句。
问题判断模块304;用于检测所述sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成相应的判断结果。
结果发送模块305;用于基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户。
在本申请的一些实施例中,所述指令执行模块302用于检测所述文件存储路径下的第一级目录中的所有文件,筛选出其中的sql文件;逐级访问所述第一级目录下的所有文件夹,直至对所述第一级目录下的所有文件夹中的文件完成检测,筛选出其中的所有sql文件。
在本申请实施例的一种具体实施方式中,所述语句提取模块303包括:调用子模块。所述调用子模块用于调用dom4j解析包或mybatis框架;通过dom4j或mybatis提供的API对所述sql文件执行解析,提取出所述sql文件中的所有sql语句。
进一步的,所述语句提取模块303还包括:规则配置子模块。所述规则配置子模块用于配置正则表达式;基于所述正则表达式匹配所述sql语句中包含in操作符的sql条件语句,并提取出匹配到的所述sql条件语句。
在本申请的一些实施例中,所述查询语句边界问题的检测装置还包括:定位信息查询模块。在所述语句提取模块303从所述sql语句中提取出包含in操作符的sql条件语句之后,所述定位信息查询模块用于解析所述sql条件语句,获取每条sql条件语句对应的id;根据所述id在所述sql语句中递归查询,以获取与所述sql条件语句匹配的类和行数。
在本申请一些实施例中,所述结果发送模块305用于当判断存在所述参数数量大于边界阈值的边界问题时,将对应的存在边界问题的sql条件语句记为异常条件语句;将所述异常条件语句及获取的与所述异常条件语句匹配的类和行数共同纳入所述推送内容。
在进一步的一种具体实施方式中,所述查询语句边界问题的检测装置还包括:统计运算模块。所述统计运算模块用于统计in操作符的总数量a,以及参数数量未超过预设的性能边界阈值x的in操作符的数量b,计算条件比例的值a/b。所述结果发送模块305还用于基于所述条件比例的值生成提示消息发送至目标用户,以向目标用户提示所述文件存储路径下sql的查询效率。
本申请实施例所述的查询语句边界问题的检测装置,通过合理的步骤对sql文件的内容进行针对性分析,判断出sql文件中的sql语句是否存在因in操作符引起的边界问题,从而方便开发人员了解sql文件中的边界问题并对问题进行定位,提高了开发的质量和对边界问题的处理时效。
为解决上述技术问题,本申请实施例还提供计算机设备。具体请参阅图4,图4为本实施例计算机设备基本结构框图。
所述计算机设备6包括通过***总线相互通信连接存储器61、处理器62、网络接口63。需要指出的是,图中仅示出了具有组件61-63的计算机设备6,但是应理解的是,并不要求实施所有示出的组件,可以替代的实施更多或者更少的组件。其中,本技术领域技术人员可以理解,这里的计算机设备是一种能够按照事先设定或存储的指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(ApplicationSpecific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable GateArray,FPGA)、数字处理器(Digital Signal Processor,DSP)、嵌入式设备等。
所述计算机设备可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机设备可以与用户通过键盘、鼠标、遥控器、触摸板或声控设备等方式进行人机交互。
所述存储器61至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等。在一些实施例中,所述存储器61可以是所述计算机设备6的内部存储单元,例如该计算机设备6的硬盘或内存。在另一些实施例中,所述存储器61也可以是所述计算机设备6的外部存储设备,例如该计算机设备6上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(FlashCard)等。当然,所述存储器61还可以既包括所述计算机设备6的内部存储单元也包括其外部存储设备。本实施例中,所述存储器61通常用于存储安装于所述计算机设备6的操作***和各类应用软件,例如查询语句边界问题的检测方法的程序代码等。此外,所述存储器61还可以用于暂时地存储已经输出或者将要输出的各类数据。
所述处理器62在一些实施例中可以是中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器、或其他数据处理芯片。该处理器62通常用于控制所述计算机设备6的总体操作。本实施例中,所述处理器62用于运行所述存储器61中存储的程序代码或者处理数据,例如运行所述查询语句边界问题的检测方法的程序代码。
所述网络接口63可包括无线网络接口或有线网络接口,该网络接口63通常用于在所述计算机设备6与其他电子设备之间建立通信连接。
本申请还提供了另一种实施方式,即提供一种计算机可读存储介质,所述计算机可读存储介质存储有查询语句边界问题的检测程序,所述查询语句边界问题的检测程序可被至少一个处理器执行,以使所述至少一个处理器执行如上述的查询语句边界问题的检测方法的步骤。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
在本申请所提供的上述实施例中,应该理解到,所揭露的装置和方法,可以通过其他的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如,多个模块或组件可以结合或者可以集成到另一个***,或一些特征可以忽略,或不执行。
所述模块或组件可以是或者也可以不是物理上分开的,作为模块或组件显示的部件可以是或者也可以不是物理模块,既可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块或组件来实现本实施例方案的目的。
本申请不限于上述实施方式,以上所述是本申请的优选实施方式,该实施例仅用于说明本申请而不用于限制本申请的范围,应当指出,对于本技术领域的普通技术人员来说,在不脱离本申请原理的前提下,其依然可以对前述各具体实施方式所记载的技术方案进行若干改进和修饰,或者对其中部分技术特征进行等效替换。凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理应视为包括在本申请的保护范围之内。
显然,以上所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例,附图中给出了本申请的较佳实施例,但并不限制本申请的专利范围。本申请可以以许多不同的形式来实现,相反地,提供这些实施例的目的是使对本申请的公开内容的理解更加透彻全面。尽管参照前述实施例对本申请进行了详细的说明,对于本领域的技术人员来而言,其依然可以对前述各具体实施方式所记载的技术方案进行修改,或者对其中部分技术特征进行等效替换。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,以及凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理在本申请专利保护范围之内。
Claims (7)
1.一种查询语句边界问题的检测方法,其特征在于,包括:
接收sql边界检测指令,所述sql边界检测指令中包含指定的文件存储路径;
响应于所述sql边界检测指令,筛选出所述文件存储路径下的所有sql文件;
提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句,其中,所述提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句的步骤之后,所述方法还包括步骤:
解析所述sql条件语句,获取每条sql条件语句对应的id;
根据所述id在所述sql语句中递归查询,以获取与所述sql条件语句匹配的类和行数;
检测所述sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成相应的判断结果;
基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户,其中,所述基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户的步骤包括:
当判断存在所述参数数量大于边界阈值的边界问题时,将对应的存在边界问题的sql条件语句记为异常条件语句;
将所述异常条件语句及获取的与所述异常条件语句匹配的类和行数共同纳入所述推送内容;
在执行所述将对应的存在边界问题的sql条件语句记为异常条件语句的步骤之后,所述方法还包括:
将所述异常条件语句中in操作符对应的所有参数值逐个且逐行***到预设的临时表中,并为每个参数值分别设置区别编号;
根据所述区别编号对应的表字段名,生成用于查询所有参数值的全量查询语句;
接收到执行所述异常条件语句的指令时,触发执行所述全量查询语句对所述临时表进行查询,获得所述异常条件语句中in操作符对应的所有参数值。
2.根据权利要求1所述的查询语句边界问题的检测方法,其特征在于,所述筛选出所述文件存储路径下的所有sql文件的步骤包括:
检测所述文件存储路径下的第一级目录中的所有文件,筛选出其中的sql文件;
逐级访问所述第一级目录下的所有文件夹,直至对所述第一级目录下的所有文件夹中的文件完成检测,筛选出其中的所有sql文件。
3.根据权利要求1所述的查询语句边界问题的检测方法,其特征在于,所述提取所述sql文件中的所有sql语句的步骤包括:
调用dom4j解析包或mybatis框架;
通过dom4j或mybatis提供的API对所述sql文件执行解析,提取出所述sql文件中的所有sql语句。
4.根据权利要求1所述的查询语句边界问题的检测方法,其特征在于,所述从所述sql语句中提取出包含in操作符的sql条件语句的步骤包括:
配置正则表达式;
基于所述正则表达式匹配所述sql语句中包含in操作符的sql条件语句,并提取出匹配到的所述sql条件语句。
5.一种查询语句边界问题的检测装置,其特征在于,所述查询语句边界问题的检测装置用于实现如权利要求1-4中任意一项所述的查询语句边界问题的检测方法的步骤,所述查询语句边界问题的检测装置,包括:
指令接收模块,用于接收sql边界检测指令,所述sql边界检测指令中包含指定的文件存储路径;
指令执行模块,用于响应于所述sql边界检测指令,筛选出所述文件存储路径下的所有sql文件;
语句提取模块,用于提取所述sql文件中的所有sql语句,并进一步从所述sql语句中提取出包含in操作符的sql条件语句;
问题判断模块,用于检测所述sql条件语句中每个in操作符对应的参数数量,判断是否存在所述参数数量大于边界阈值的边界问题,并生成相应的判断结果;
结果发送模块,用于基于所述判断结果生成用于提示边界问题的推送内容发送至目标用户。
6.一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器执行所述计算机程序时实现如权利要求1-4中任意一项所述的查询语句边界问题的检测方法的步骤。
7.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1-4中任意一项所述的查询语句边界问题的检测方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910902759.1A CN110851346B (zh) | 2019-09-24 | 2019-09-24 | 查询语句边界问题的检测方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910902759.1A CN110851346B (zh) | 2019-09-24 | 2019-09-24 | 查询语句边界问题的检测方法、装置、设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110851346A CN110851346A (zh) | 2020-02-28 |
CN110851346B true CN110851346B (zh) | 2024-05-31 |
Family
ID=69596014
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910902759.1A Active CN110851346B (zh) | 2019-09-24 | 2019-09-24 | 查询语句边界问题的检测方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110851346B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115516442A (zh) * | 2020-04-27 | 2022-12-23 | 樊文飞 | 在有限资源下查询大数据 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104765731A (zh) * | 2014-01-02 | 2015-07-08 | 国际商业机器公司 | 数据库查询优化方法和设备 |
CN106919612A (zh) * | 2015-12-25 | 2017-07-04 | ***通信集团浙江有限公司 | 一种上线结构化查询语言脚本的处理方法及装置 |
CN107748658A (zh) * | 2017-09-30 | 2018-03-02 | 银联商务股份有限公司 | 一种软件开发方法、***、计算机可读存储介质及电子设备 |
CN107832055A (zh) * | 2017-12-11 | 2018-03-23 | 安徽科大国创云网科技有限公司 | 一种mql语言翻译为sql语言的方法 |
CN108121542A (zh) * | 2017-11-17 | 2018-06-05 | 广东睿江云计算股份有限公司 | 一种基于MyBatis的SQL语句的配置方法、*** |
CN108984612A (zh) * | 2018-06-12 | 2018-12-11 | 中国平安人寿保险股份有限公司 | 目标sql语句的获取方法、装置、计算机设备及存储介质 |
CN109271315A (zh) * | 2018-08-23 | 2019-01-25 | 中国平安财产保险股份有限公司 | 脚本代码检测方法、装置、计算机设备及存储介质 |
CN109325042A (zh) * | 2018-08-14 | 2019-02-12 | 中国平安人寿保险股份有限公司 | 处理模版获取方法、表格处理方法、装置、设备及介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8452754B2 (en) * | 2009-05-08 | 2013-05-28 | Microsoft Corporation | Static analysis framework for database applications |
-
2019
- 2019-09-24 CN CN201910902759.1A patent/CN110851346B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104765731A (zh) * | 2014-01-02 | 2015-07-08 | 国际商业机器公司 | 数据库查询优化方法和设备 |
CN106919612A (zh) * | 2015-12-25 | 2017-07-04 | ***通信集团浙江有限公司 | 一种上线结构化查询语言脚本的处理方法及装置 |
CN107748658A (zh) * | 2017-09-30 | 2018-03-02 | 银联商务股份有限公司 | 一种软件开发方法、***、计算机可读存储介质及电子设备 |
CN108121542A (zh) * | 2017-11-17 | 2018-06-05 | 广东睿江云计算股份有限公司 | 一种基于MyBatis的SQL语句的配置方法、*** |
CN107832055A (zh) * | 2017-12-11 | 2018-03-23 | 安徽科大国创云网科技有限公司 | 一种mql语言翻译为sql语言的方法 |
CN108984612A (zh) * | 2018-06-12 | 2018-12-11 | 中国平安人寿保险股份有限公司 | 目标sql语句的获取方法、装置、计算机设备及存储介质 |
CN109325042A (zh) * | 2018-08-14 | 2019-02-12 | 中国平安人寿保险股份有限公司 | 处理模版获取方法、表格处理方法、装置、设备及介质 |
CN109271315A (zh) * | 2018-08-23 | 2019-01-25 | 中国平安财产保险股份有限公司 | 脚本代码检测方法、装置、计算机设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN110851346A (zh) | 2020-02-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11755387B1 (en) | Updating code of an app feature based on a value of a query feature | |
CN110764682B (zh) | 页面控制方法、装置和计算机可读存储介质 | |
US10699061B2 (en) | Application page quick access | |
US8756593B2 (en) | Map generator for representing interrelationships between app features forged by dynamic pointers | |
US8589876B1 (en) | Detection of central-registry events influencing dynamic pointers and app feature dependencies | |
CN110162408B (zh) | 一种数据处理方法、装置、设备和机器可读介质 | |
KR20150143605A (ko) | 표시할 메시지 데이터 결정 | |
CN112394908A (zh) | 埋点页面自动生成的方法、装置、计算机设备及存储介质 | |
CN111651296A (zh) | 数据删除操作的拦截备份方法、装置、设备及存储介质 | |
WO2021189766A1 (zh) | 数据可视化方法及相关设备 | |
CN109240664A (zh) | 一种采集用户行为信息的方法及终端 | |
CN110851346B (zh) | 查询语句边界问题的检测方法、装置、设备及存储介质 | |
CN112363814A (zh) | 任务调度方法、装置、计算机设备及存储介质 | |
EP3594823B1 (en) | Information display method, terminal and server | |
CN108268298A (zh) | 桌面图标的生成方法、装置、存储介质及电子设备 | |
CN111782208A (zh) | 指标预警方法、装置、计算机设备及存储介质 | |
CN113282591B (zh) | 权限过滤方法、装置、计算机设备及存储介质 | |
US9372936B2 (en) | Partial data report generation with data costing notification | |
CN111259259B (zh) | 大学生新闻推荐方法、装置、设备及存储介质 | |
CN111104620B (zh) | 网页浏览方法、服务器及*** | |
RU2715287C1 (ru) | Способ, терминал и сервер для отображения информации | |
CN116389409A (zh) | 页面路径的处理方法、装置、计算机设备及存储介质 | |
CN115185798A (zh) | 数据采集分析方法、装置、电子设备及存储介质 | |
CN110851133A (zh) | 前端组件库、基于前端组件库的网页响应方法及装置 | |
CN117667668A (zh) | 基于应用升级的应用分析方法、装置、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |