分30条依次解析xml并插入数据库成功
package xxx; import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; import xxx.hf.jdbc.StoreIntoMysql; /*
* 解析30条后插入到数据,然后继续插入
*
* */
public class XmlToMysql {
private Document doc = null;
public XmlToMysql(String xmlFile) {
try {
SAXReader reader = new SAXReader();
doc = reader.read(xmlFile); } catch (Exception e) {
e.printStackTrace();
}
} /*
* 返回解析到的元素个数
*/
public int getInfos(String str, String sds) { // str ="Patient";
ArrayList<String[]> infos = new ArrayList<String[]>();
// 标识是最后的30条记录或者不足30条
boolean last = false; // 获得所有str元素
List strs = doc.selectNodes("//" + str); System.out.println(strs.size()); // System.exit(0);
// 遍历指定的所有元素
for (int j = 0; j < strs.size(); j++) {
Element eAdd = ((Element) strs.get(j));
// 遍历指定元素的子元素
String[] strArray = null;
if (str.equals("Patient")) {
strArray = new String[16]; } else {
strArray = new String[15];
}
int m = 0;
for (Iterator i = eAdd.elementIterator(); i.hasNext();) {
Element node = (Element) i.next();
// System.out.println(node.getName() + ":" + node.getText());
// 处理特别的字符串
if (node.getText().indexOf(":") > 0) {
// 这里处理时间问题,插入datetime不会出错
strArray[m] = node.getText().toString().substring(0, 19)
.replace("T", " "); } else {
strArray[m] = node.getText().toString(); }
m++; }
infos.add(strArray); // 判断是否到达最后1条记录
if (j == (strs.size() - 1)) {
System.out.println("这是最后一条记录");
System.out.println(j);
// 设置标识
last = true;
} // 如果集合的长度有30条,就commit一次
// 或则是最后一条记录的时候
if (infos.size() >= 30 || last) {
// 存入数据库
if(str.equals("Patient")){
StoreIntoMysql.StorePatient(infos, sds + str); }else{
StoreIntoMysql.StoreTreat(infos, sds + str); }
// 集合清空
infos.clear(); } } return strs.size();
} }
主要的问题是在于,最后的30条或不足30条。
这里采用的一个变量来判断
这里发现的问题是:集合的清空,我用的clear方法,但是手册中提示过时了,removeAll() 方法没看懂怎么用
分30条依次解析xml并插入数据库成功的更多相关文章
- 使用XStream解析复杂XML并插入数据库(二)
标注黄色地方:我需要加深学习!!! 我写的是webservice,目前具体写webservice的步骤我还不清楚, 整理完小知识开始整理webservice! 针对以下格式的XML进行解析 <? ...
- 使用XStream解析复杂XML并插入数据库(一)
环境: Springboot+mysql 我只想说jpa真的超级好用,准备深入研究一下~ 导入依赖: <dependency> <groupId>org.projectlomb ...
- python3.4.3 调用http接口 解析response xml后插入数据库
工作中需要调用一个http的接口,等不及java组开发,就试着用python去调用.Python版本3.4.3 完整的流程包括:从sqlServer取待调用的合同列表 -> 循环调用http接口 ...
- java中解析excel 批量插入数据库
Facade 层 实现类 (@Service("samePeriodModelImportFacade")) 1. 获取cells 的方法 public Cells getCel ...
- jsp--提交表单→插入数据库→成功后返回提示信息
<%@ page language="java" import="java.util.*,java.sql.*" pageEncoding="u ...
- Linux Shell | 解析xml节点
01 xml文件 # user.xml <user> <name>Toy</name> <sex>man</sex> <room/&g ...
- Java MyBatis 插入数据库返回主键
最近在搞一个电商系统中由于业务需求,需要在插入一条产品信息后返回产品Id,刚开始遇到一些坑,这里做下笔记,以防今后忘记. 类似下面这段代码一样获取插入后的主键 User user = new User ...
- MyBatis 插入数据库返回主键
最近在搞一个电商系统中由于业务需求,需要在插入一条产品信息后返回产品Id,刚开始遇到一些坑,这里做下笔记,以防今后忘记. 类似下面这段代码一样获取插入后的主键 User user = new User ...
- Ajax实现xml文件数据插入数据库(一)--- 构建解析xml文件的js库
Ajax实现将xml文件数据插入数据库的过程所涉及到的内容比较多,所以对于该过程的讲解本人打算根据交互的过程将其分为三个部分,第一部分为构建解析xml文件的javascript库,第二部分为ajax与 ...
随机推荐
- Android Studio开发环境的配置
为了使开发人员与时俱进, 在这里给大家讲解一下Android Studio的安装步骤及设置. 使用的是Android的最新版本,0.4.2版本,Android Studio可以脱离Eclipse单独运 ...
- linux logrotate配置
对于Linux 的系统安全来说,日志文件是极其重要的工具.系统管理员可以使用logrotate 程序用来管理系统中的最新的事件,对于Linux 的系统安全来说,日志文件是极其重要的工具.系统管理员可以 ...
- java集合框架map
Map<K,V> K key V value Map集合:该集合存储键值对.一对一对往里存,而且要保证键的唯一性. 1,添加. 2,删除. 3,判断. 4,获取. Map |--Hasht ...
- Android中的自定义Adapter(继承自BaseAdapter)——与系统Adapter的调用方法一致——含ViewHolder显示效率的优化(转)
Android中很多地方使用的是适配器(Adapter)机制,那我们就要好好把这个Adapter利用起来,并且用出自己的特色,来符合我们自行设计的需要喽~~~ 下面先上一个例子,是使用ViewHold ...
- opencart配置
1.安装opencart 2.修改后台目录(慎重,修改后插件安装会出错) Opencart默认的后台是网站/admin这样子,很多人可以猜到这种组合对于正式生产环境很不安全,我们可以把这个admin改 ...
- IFeatureLayer
All Properties Methods Inherited Non-inherited Description AreaOfInterest The default area of inte ...
- ural1613 For Fans of Statistics
For Fans of Statistics Time limit: 1.0 secondMemory limit: 64 MB Have you ever thought about how man ...
- 《accelerated c++》---------第六章
本章主要讲了算法部分.就是<algoruthm>里面的算法.
- tls session resumption
http://stackoverflow.com/questions/12318325/resume-tls-connection-in-java As long as you use the sam ...
- POJ 3494 Largest Submatrix of All 1’s
POJ 2796 Feel Good HDU 1506 Largest Rectangle in a Histogram 和这两题一样的方法. #include<cstdio> #incl ...