[发明专利]一种将XML文件的内容导入数据库的方法和装置有效
申请号: | 201510697080.5 | 申请日: | 2015-10-22 |
公开(公告)号: | CN105320763B | 公开(公告)日: | 2019-06-07 |
发明(设计)人: | 李强 | 申请(专利权)人: | 江苏国泰新点软件有限公司 |
主分类号: | G06F16/84 | 分类号: | G06F16/84 |
代理公司: | 北京市隆安律师事务所 11323 | 代理人: | 权鲜枝;何立春 |
地址: | 215600 江苏*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 数据库 读取 方法和装置 内存 可扩展标记语言 数据存储结构 存储结构 获取数据 流方式 保存 加载 崩溃 | ||
1.一种将可扩展标记语言XML文件的内容导入数据库的方法,其特征在于,该方法包括:
采用流方式将XML文件中的XML数据加载到内存中;
从内存中的所述XML数据中获取数据并保存到指定数据表中;所述指定数据表的数据存储结构与指定数据库相同;
将所述指定数据表中的数据导入所述指定数据库中;
所述采用流方式将XML文件中的XML数据加载到内存中进一步包括:
基于XPathDocument类派生出执行流方式的方法,由该方法采用流方式将XML文件中的XML数据加载到内存中;
所述从内存中的所述XML数据中获取数据并保存到指定数据表中包括:
确定内存中的所述XML数据中的节点集;
遍历内存中的所述XML数据,读取所述节点集中的各个节点,从各个节点中获取数据并保存到所述指定数据表中;
所述遍历内存中的所述XML数据,读取所述节点集中的各个节点,从各个节点中获取数据并保存到所述指定数据表中包括:
基于XPathNavigator类派生出可获取当前节点的父节点属性的方法,由该方法遍历所述节点集中的各个节点,获取各个节点的属性值并保存到所述指定数据表中。
2.如权利要求1所述的方法,其特征在于,所述将所述指定数据表中的数据导入所述指定数据库中包括:
调用SqlBulkCopy类将所述指定数据表中的数据导入所述指定数据库中。
3.如权利要求2所述的方法,其特征在于,所述调用SqlBulkCopy类将所述指定数据表中的数据导入所述指定数据库中进一步包括:
读取Oracle客户端的配置文件,获取Oracle.DataAccess.dll文件的路径信息;
根据所述路径信息调用所述Oracle.DataAccess.dll文件,根据该文件调用SqlBulkCopy类将所述指定数据表中的数据导入所述指定数据库中。
4.一种将可扩展标记语言XML文件的内容导入数据库的装置,其特征在于,该装置包括:
加载单元,用于采用流方式将XML文件中的XML数据加载到内存中;
数据获取单元,用于从内存中的所述XML数据中获取数据并保存到指定数据表中;所述指定数据表的数据存储结构与指定数据库相同;
数据导入单元,用于将所述指定数据表中的数据导入所述指定数据库中;
所述加载单元,基于XPathDocument类派生出执行流方式的方法,由该方法采用流方式将XML文件中的XML数据加载到内存中;
所述数据获取单元,用于确定内存中的所述XML数据中的节点集;遍历内存中的所述XML数据,读取所述节点集中的各个节点,从各个节点中获取数据并保存到所述指定数据表中;
所述数据获取单元,基于XPathNavigator类派生出可获取当前节点的父节点属性的方法,由该方法遍历所述节点集中的各个节点,获取各个节点的属性值并保存到所述指定数据表中。
5.如权利要求4所述的装置,其特征在于,所述数据导入单元,调用SqlBulkCopy类将所述指定数据表中的数据导入所述指定数据库中。
6.如权利要求5所述的装置,其特征在于,所述数据导入单元,进一步用于读取Oracle客户端的配置文件,获取Oracle.DataAccess.dll文件的路径信息;根据所述路径信息调用所述Oracle.DataAccess.dll文件,根据该文件调用SqlBulkCopy类将所述指定数据表中的数据导入所述指定数据库中。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于江苏国泰新点软件有限公司,未经江苏国泰新点软件有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201510697080.5/1.html,转载请声明来源钻瓜专利网。
- 上一篇:具有饱和燃料储备的液化天然气运输系统
- 下一篇:马达