[发明专利]基于Java语言的SQL脚本生成方法、装置、设备及存储介质在审
申请号: | 202210730920.3 | 申请日: | 2022-06-24 |
公开(公告)号: | CN114969099A | 公开(公告)日: | 2022-08-30 |
发明(设计)人: | 陈晟豪 | 申请(专利权)人: | 平安普惠企业管理有限公司 |
主分类号: | G06F16/242 | 分类号: | G06F16/242;G06F8/30 |
代理公司: | 深圳市沃德知识产权代理事务所(普通合伙) 44347 | 代理人: | 高杰;于志光 |
地址: | 518000 广东省深圳市*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 java 语言 sql 脚本 生成 方法 装置 设备 存储 介质 | ||
本发明涉及数据处理技术,揭露了一种基于Java语言的SQL脚本生成方法,包括:读取SQL脚本结构所在的Excel中的表结构信息、函数信息作为目标信息;将目标信息的字段名称及其对应的索引值拼接,得到第一拼接结果;解析第一拼接结果中的各关键字并据此在目标信息中查找对应的参数值;将所述参数值转化为对应类型的SQL语句;监视所述参数值转化为SQL语句的转化进度;当所述转化进度达到预设进度阈值时,将所述对应类型的SQL语句写入预设的指定文件,得到与所述SQL语句对应的SQL脚本。此外,本发明还涉及区块链技术,SQL语句可存储于区块链的节点。本发明还提出一种基于Java语言的SQL脚本生成装置、电子设备以及存储介质。本发明可以提高SQL脚本的适用范围。
技术领域
本发明涉及数据处理技术领域,尤其涉及一种基于Java语言的SQL脚本生成方法、装置、电子设备及计算机可读存储介质。
背景技术
随着软件开发者需求的多样化,在软件开发市场上提供了越来越多的SQL脚本,但为了给开发者更好的使用体验,提高SQL脚本的适用范围,需要根据不同的数据库内的语法信息,以进行基于Java语言的SQL脚本生成。
现有的SQL脚本多针对基于单一的数据库生成,基本上只生成数据定义语句,数据操作语句基本上不做生成。例如,只针对自己每个项目用的数据库类型来开发小工具。实际应用中,不同的语法生成的SQL脚本不一样,仅考虑单一属性,可能导致生成的SQL脚本过于单一,只适用于自己单一的项目,从而使生成的SQL脚本的适用范围降低。
发明内容
本发明提供一种基于Java语言的SQL脚本生成方法、装置及计算机可读存储介质,其主要目的在于解决生成的SQL脚本的适用范围降低的问题。
为实现上述目的,本发明提供的一种基于Java语言的SQL脚本生成方法,包括:
利用Java POI提供的文档读写功能读取SQL脚本结构所在的Excel中的表结构信息以及函数信息作为目标信息;
依据预设的StringBulider拼接符将每个目标信息的字段名称以及所述字段名称对应的索引值进行拼接,得到第一拼接结果;
解析所述第一拼接结果中的各个关键字,依据所述各个关键字在所述目标信息中查找对应的参数值;
利用Java IO将所述参数值转化为对应类型的SQL语句;
通过预设的Javaswing组件监视所述参数值转化为SQL语句的转化进度;
当所述转化进度达到预设进度阈值时,将所述对应类型的SQL语句写入预设的指定文件,得到与所述SQL语句对应的SQL脚本。
可选地,所述利用Java POI提供的文档读写功能读取SQL脚本结构所在的Excel中的表结构信息以及函数信息作为目标信息,包括:
通过所述JavaPOI内的ExcelReader.java类解析所述表结构信息以及函数信息;
利用ExcelDataVO.java类将解析后的表结构信息以及函数信息进行封装,得到所述目标信息。
可选地,所述依据预设的StringBulider拼接符将每个目标信息的字段名称以及所述字段名称对应的索引值进行拼接,得到第一拼接结果,包括:
获取所述目标信息的字段名称以及所述字段名称对应的索引值;
将所述目标信息的字段名称以及所述字段名称对应的索引值作为关键字,利用预设的StringBulider拼接符将所述关键字拼接为所述第一拼接结果。
可选地,所述解析所述第一拼接结果中的各个关键字,依据所述各个关键字在所述目标信息中查找对应的参数值,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安普惠企业管理有限公司,未经平安普惠企业管理有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210730920.3/2.html,转载请声明来源钻瓜专利网。