本申请提供了一种Excel文件导入数据库的方法及电子设备,涉及数据领域。该方法通过根据待导入Excel文件对应的配置信息确定其要导入的目标数据库,然后根据预先设置不同数据库对应的语句转换规则,从中选取目标数据库的转换规则并对待导入Excel文件中的数据进行解析,基于解析后的数据生成目标数据库中的数据表,实现待导入Excel文件数据的导入,该方法无需用户考虑待导入Excel文件的行列情形,能够实现自动将Excel文件导入数据库,提高导入Excel文件的效率。Excel文件的效率。Excel文件的效率。
【技术实现步骤摘要】
Excel文件导入数据库的方法及电子设备
[0001]本申请涉及数据处理
,尤其涉及一种Excel文件导入数据库的方法及电子设备。
技术介绍
[0002]目前将Excel文件中的数据导入数据库的过程,一般包括读取Excel文件、获取Excel数据类型并校验,创建数据库连接,然后利用数据库引擎创建临时表,再通过结构化查询语言数据库(Structured Query Language,SQL)进行数据导入。
[0003]一种将Excel文件进行数据导入数据库的方法是,通过Excel VBA宏语言(Visual Basicfor Applications)脚本进行导入。然而,该导入方式受制于Excel的特点以及VBA编程,需要提前创建好数据表并需要数据项一一对应,这就需要一定数据库编程基础和VBA编程基础方能成功实现Excel数据导入。
[0004]现有的Excel数据导入数据库的方式不仅复杂,还对用户的编程技能具有一定要求,无法满足常规用户需求,导致用户体验不佳。
技术实现思路
[0005]本申请实施例提供了一种Excel文件导入数据库的方法及电子设备,该方法通过自动将导Excel文件导入目标数据库的流程,解决用户手动导入Excel文件存在的效率低下的问题。
[0006]第一方面,提供了一种Excel文件导入数据库的方法,应用于电子设备,所述方法包括:
[0007]获取多个数据库对应的语句转换规则,并生成所述数据库与所述语句转换规则之间的对应关系;
[0008]接收待导入Excel文件和第一配置信息;
[0009]根据预存储的所述数据库与所述配置信息之间的对应关系,获取所述第一配置信息对应的目标数据库,所述目标数据库为所述多个数据库中的一个,且所述目标数据库为所述待导入Excel文件将要导入的数据库;
[0010]根据所述目标数据库获取对应的目标语句转换规则,并根据所述目标语句转换规则对所述待导入Excel文件中的数据进行解析,获取解析结果,并根据所述解析结果获取所述待导入Excel文件的最大行记录数和数据类型;
[0011]根据所述待导入Excel文件的最大行记录数和数据类型在所述目标数据库构建目标数据表;
[0012]将所述解析结果中的待导入数据插入所述目标数据表。
[0013]根据本申请实施例提供的Excel文件导入数据库的方法,通过根据待导入Excel文件对应的配置信息确定其要导入的目标数据库,然后根据预先设置不同数据库对应的语句转换规则,从中选取目标数据库的转换规则并对待导入Excel文件中的数据进行解析,基于
解析后的数据生成目标数据库中的数据表,实现待导入Excel文件数据的导入,该方法无需用户考虑待导入Excel文件的行列情形,能够实现自动将Excel文件导入数据库,提高导入Excel 文件的效率。
[0014]结合第一方面,在第一方面的某些实现方式中,所述方法还包括:
[0015]对所述待导入Excel文件中的数据进行校验,获取所述待导入Excel文件中的行信息和列信息,所述行信息包括行数量和每行包括的字符信息,所述列信息包括列数量和每列包括的字符信息;
[0016]当所述校验的结果符合预设规则时,根据所述目标语句转换规则对所述待导入Excel文件中的数据进行解析。
[0017]结合第一方面,在第一方面的某些实现方式中,所述方法还包括:
[0018]当所述校验的结果不符合预设规则时,生成通知消息,所述通知消息用于指示所述待导入Excel文件不符合预设规则;
[0019]向用户提示所述通知消息。
[0020]结合第一方面,在第一方面的某些实现方式中,所述通知消息还包括所述待导入Excel 文件不符合预设规则的具体事项。
[0021]结合第一方面,在第一方面的某些实现方式中,所述方法还包括:
[0022]将所述解析结果存储至所述电子设备的内存;
[0023]读取所述解析结果中的行信息、列信息和表头信息;
[0024]根据所述行信息、列信息和表头信息获取所述最大行记录数和数据类型。
[0025]结合第一方面,在第一方面的某些实现方式中,当将待导入数据插入所述目标数据表之后,所述方法还包括:
[0026]获取所述待导入Excel文件导入所述目标数据库的导入状态,所述导入状态用于指示所述待导入Excel文件导入所述目标数据库成功或失败;
[0027]向用户提示所述导入状态。
[0028]结合第一方面,在第一方面的某些实现方式中,所述电子设备包括接收模块、转换模块、校验模块、解析模块、创建模块,所述方法还包括:
[0029]所述接收模块获取多个数据库对应的语句转换规则,并生成所述数据库与所述语句转换规则之间的对应关系;接收待导入Excel文件和第一配置信息;
[0030]所述转换模块根据预存储的所述数据库与所述配置信息之间的对应关系,获取所述第一配置信息对应的目标数据库,所述目标数据库为所述多个数据库中的一个,且所述目标数据库为所述待导入Excel文件将要导入的数据库,根据所述目标数据库获取对应的目标语句转换规则;
[0031]所述解析模块根据所述目标语句转换规则对所述待导入Excel文件中的数据进行解析,获取解析结果,并根据所述解析结果获取所述待导入Excel文件的最大行记录数和数据类型;
[0032]所述创建模块根据所述待导入Excel文件的最大行记录数和数据类型在所述目标数据库构建目标数据表;将所述解析结果中的待导入数据插入所述目标数据表。
[0033]结合第一方面,在第一方面的某些实现方式中,所述电子设备包括校验模块、解析模块,所述方法还包括:
[0034]所述校验模块对所述待导入Excel文件中的数据进行校验,获取所述待导入Excel文件中的行信息和列信息,所述行信息包括行数量和每行包括的字符信息,所述列信息包括列数量和每列包括的字符信息;
[0035]所述解析模块用于当所述校验的结果符合预设规则时,根据所述目标语句转换规则对所述待导入Excel文件中的数据进行解析。
[0036]第二方面,提供了一种电子设备,包括:一个或多个处理器;一个或多个存储器;所述一个或多个存储器存储有一个或多个计算机程序,所述一个或多个计算机程序包括指令,当所述指令被所述一个或多个处理器执行时,使得所述电子设备执行如上述第一方面中任一实现方式所述的方法。
[0037]第三方面,提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可执行程序指令,所述计算机可执行程序指令在被计算机上运行时,使所述计算机执行如上述第一方面中任一实现方式所述的方法。
[0038]第四方面,提供了一种计算机程序产品,所述计算机程序产品包括计算机程序代码,当所述计算机程序代码在计算机上运行时,使所述计算机执行如上述第一方面中任一实现方式所述的方法。
附图说明
...
【技术保护点】
【技术特征摘要】
1.一种Excel文件导入数据库的方法,其特征在于,应用于电子设备,所述方法包括:获取多个数据库对应的语句转换规则,并生成所述数据库与所述语句转换规则之间的对应关系;接收待导入Excel文件和第一配置信息;根据预存储的所述数据库与所述配置信息之间的对应关系,获取所述第一配置信息对应的目标数据库,所述目标数据库为所述多个数据库中的一个,且所述目标数据库为所述待导入Excel文件将要导入的数据库;根据所述目标数据库获取对应的目标语句转换规则,并根据所述目标语句转换规则对所述待导入Excel文件中的数据进行解析,获取解析结果,并根据所述解析结果获取所述待导入Excel文件的最大行记录数和数据类型;根据所述待导入Excel文件的最大行记录数和数据类型在所述目标数据库构建目标数据表;将所述解析结果中的待导入数据插入所述目标数据表。2.根据权利要求1所述的方法,其特征在于,所述方法还包括:对所述待导入Excel文件中的数据进行校验,获取所述待导入Excel文件中的行信息和列信息,所述行信息包括行数量和每行包括的字符信息,所述列信息包括列数量和每列包括的字符信息;当所述校验的结果符合预设规则时,根据所述目标语句转换规则对所述待导入Excel文件中的数据进行解析。3.根据权利要求2所述的方法,其特征在于,所述方法还包括:当所述校验的结果不符合预设规则时,生成通知消息,所述通知消息用于指示所述待导入Excel文件不符合预设规则;向用户提示所述通知消息。4.根据权利要求3所述的方法,其特征在于,所述通知消息还包括所述待导入Excel文件不符合预设规则的具体事项。5.根据权利要求1
‑
4中任一项所述的方法,其特征在于,所述方法还包括:将所述解析结果存储至所述电子设备的内存;读取所述解析结果中的行信息、列信息和表头信息;根据所述行信息、列信息和表头信息获取所述最大行记录数和数据类型。6.根据权利要求1
‑
5中任一项所述的方法,其特征在于,当将待导入数据插入所述目标数据表之后,所述方法还包括:获取所述待导入Excel文件导入所述目标数据库的导入状态,所述导入状态用于指示所述待...
【专利技术属性】
技术研发人员:段建团,齐超,
申请(专利权)人:北京博导前程信息技术股份有限公司,
类型:发明
国别省市:
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。