分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与 ...
随机推荐
- APK反编译(Linux环境下)
先下载dex2jar和jd-gui这两个软件,然后解压APK,把解压出来的classes.dex,放到dex2jar的根目录,然后命令行进入到dex2jar根目录,然后执行命令 ./dex2jar ...
- 设置自己Eclipse代码风格(内部)
http://www.cnblogs.com/farseer810/p/4391318.html 经过这几次的代码提交,发现很多人的代码风格不够规范.个人认为很有必要强制性规定一下代码的规范. 整体来 ...
- STL笔记之【map之移除元素】
//---------------------------------------------------------// 移除map中满足条件的元素//----------------------- ...
- 改MAC地址
Google TMAC v6. Or click here
- Entity Framework 学习初级篇6--EntityClient
System.Data.EntityClient 命名空间是 实体框架的 .NET Framework 数据提供程序.EntityClient 提供程序使用存储特定的 ADO.NET 数据提供程序类和 ...
- 我也谈javascript正则匹配
一.javascript 正则全局匹配 g 慎用test()方法 来个例子: var a = /^[a-z]+/gi; a.test('bb123'); //true a.lastIndex ; // ...
- 介绍Angular的注入服务
其实angular的注入服务是挺复杂的,目前看源码也只看懂了一半,为了不误导大家,我也不讲敢讲太复杂,怕自己都理解错了. 首先我们要知道angular的三种注入方式: 第一种:inference va ...
- 1381: Munching(BFS)
Description Bessie loves her grass and loves to hurry to the barn for her evening milking session. S ...
- Android客户端通过socket与服务器通信
android端--Client package com.sec.chatroomandroid; import java.io.BufferedReader; import java.io.Buff ...
- urllib2修改header
python网络访问的标准模块 urllib与urllib2并不是升级版的关系,具体可见谷歌文章:difference between urllib and urllib2urllib2的官方文档:h ...