使用XStream解析复杂XML并插入数据库(一)
环境:
Springboot+mysql
我只想说jpa真的超级好用,准备深入研究一下~
导入依赖:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.18</version>
</dependency>
lombok项目对于生成ToString(),Setter(),Getter()方法真的是太方便了。
Intellij idea开发的话需要安装Lombok plugin,同时设置 Setting -> Compiler -> Annotation Processors -> Enable annotation processing勾选。不过我没有勾选。 参考:http://www.cnblogs.com/holten/p/5729226.html
https://yq.aliyun.com/articles/59972
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc14</artifactId>
<version>10.2.0.4.0</version>
</dependency>
<dependency>
<groupId>com.thoughtworks.xstream</groupId>
<artifactId>xstream</artifactId>
<version>1.4.9</version>
</dependency> 根据下列链接成功完成一个Demo:
http://blog.csdn.net/yucaifu1989/article/details/26476835 XStream注解说明:
http://blog.csdn.net/gaozhlzh/article/details/6826140
https://www.cnblogs.com/vmkash/p/5524809.html
jdbc连接池:
http://blog.csdn.net/emperor_xdy/article/details/6892607
很全的各种举例:
https://www.cnblogs.com/XL-Liang/archive/2013/03/22/2974987.html
其余有价值参考:
https://www.cnblogs.com/johnsonwei/p/5778406.html
http://blog.csdn.net/rainbow_m/article/details/47783337
http://blog.csdn.net/yobsun/article/details/51890656
https://www.cnblogs.com/zr520/archive/2016/04/06/5357459.html
http://blog.csdn.net/white_smile/article/details/43085491 项目中我使用了Hibernate去生成表,Hibernate具体使用我还不太会。不过也就是表问题。jdbc插入使用PreparedStatement,jpa插入先贴代码,后续我再研究研究。
复杂XML目前我见过两种(不涉及属性的研究):
(1)包含很多子模块
比较有代表性大概这样的:
<?xml version="1.0" encoding="GBK" standalone="no"?>
<Demo>
<A>
<a1></a1>
<a2></a2>
</A>
<B>
<b1></b1>
<b2></b2>
</B>
<C>
<D>
<cd1></cd1>
<cd2><cd2>
</D>
</C>
</Demo>
以下链接中的例子完美解决了上述情况:
http://blog.csdn.net/yucaifu1989/article/details/26476835
(2)、成段重复
我遇到的是这样的情况:
<?xml version=”1.0” encoding=”UTF-8”?>
<Data>
<Bean>
<A>a</A>
<B>b</B>
<C>1</C>
<A>a</A>
<B>b</B>
<C>2</C>
<D>
<F></F>
</D>
</Bean>
</Data>
分析:
要求将返回来的xml解析成java对象并插入数据库,将XML中的内容分成两个表,实现一对多的关系。有用的字段为A、B、C。
one表:A、B
more表:C 方法一:
创建三个类:分别是Data(),Bean(),D()
Bean()类中以集合或者数组存储ABC和对象D。
//jpa注解@Data可以生成tostring(),setter(),getter()方法
@Data
public class Bean {
private List<String> A;
private List<String> B;
private List<String> C;
private D d;
}
这里我们有类Data(),那么就不能使用@Data注解了,可以手动写get()、set()方法
public class Data {
private Bean BEAN; public Bean getBean() {
return BEAN;
} public void setBean(Bean BEAN) {
this.BEAN = BEAN;
}
}
D类省略。
再写一个转换的类
public class ParseXmlUtil {
/**
* 序列化XML字符串为对象
*
* @param xml xml字符串
*
* @return Channels对象
*/
public static Data fromXML(String xml) {
/**
* new DomDriver()用于解决java.lang.NoClassDefFoundError: org/xmlpull/v1/XmlPullParserFactory问题
*/ XStream xstream = new XStream(new DomDriver());
xstream.processAnnotations(Bean.class);
xstream.processAnnotations(Data.class);
xstream.alias("DATA", Data.class);
xstream.alias("BEAN", Bean.class);
xstream.alias("A", String.class);
xstream.addImplicitCollection(Bean.class, "A");
xstream.alias("B", String.class);
xstream.addImplicitCollection(Bean.class, "B");
xstream.alias("C", String.class);
xstream.addImplicitCollection(Bean.class,"C");
xstream.alias("D", D.class);
return (Data) xstream.fromXML(xml);
}
}
解析可以了,现在写用于插入数据库的:
application.properties配置文件:
server.port=8088 #oracle
#driver=oracle.jdbc.driver.OracleDriver
#url=jdbc:oracle:thin:@10.95.18.124:1521:orcl
#spring.datasource.url=jdbc:oracle:thin:@localhost:1521:orcl
#username=root
#password=root
#mysql
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/work
username=root
password=root #配置JPA
#spring.jpa.database=oracle
spring.jpa.database=mysql
spring.jpa.show-sql=true
spring.jpa.generate-ddl=true
我使用mysql。
public class ConnectionUtils {
private static String url;
private static String driver;
private static String username;
private static String password;
static{
Properties props = new Properties();
try {
//从属性文件中读取数据库配置信息
props.load(ConnectionUtils.class.getClassLoader()
.getResourceAsStream("application.properties"));
} catch (IOException e) {
e.printStackTrace();
}
if(props != null){
url = props.getProperty("url");
driver = props.getProperty("driver");
username = props.getProperty("username");
password = props.getProperty("password");
//装载并注册数据库驱动
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(url, username, password);
} public static void close(Connection con) {
try {
if (con != null) {
con.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} public static void close(PreparedStatement stmt) {
try {
if (stmt != null) {
stmt.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} public static void close(ResultSet rs) {
try {
if (rs != null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} }
测试:
public class Test {
public static void main(String[] args) { String sqlOne = "insert into one(A,B) " +
"values(?,?);"; String sqlMore = "insert into more(one_id,C) " +
"values(?,?);"; Connection conn = null;
PreparedStatement pstmt = null;
PreparedStatement pst = null; try {
conn = ConnectionUtils.getConnection();
pstmt = (PreparedStatement) conn.prepareStatement(sqlOne);
String code = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" +
"\n" +
"<DATA> \n" +
" <BEAN> \n" +
" <A>2018-01-22</A> \n" +
" <B>太原</B> \n" +
"<C>1</C>\n" + " <A>2018-01-22</A> \n" +
" <B>太原</B> \n" +
"<C>2</C>\n" +
"<D><F>enen</F></D>"+
" </BEAN> \n" +
"</DATA>\n";
Data data = (Data) ParseXmlUtil.fromXML(code);
Bean bean = data.getBean();
pstmt.setString(1, bean.getA().get(0));
pstmt.setString(2, bean.getB().get(0)); for (int i = 0; i < bean.getA().size(); i++) {
pst = (PreparedStatement) conn.prepareStatement(sqlMore);
pstmt.setString(1, bean.getC().get(i));
pstmt.addBatch();
}
pstmt.executeBatch();//批量增加 System.out.println("将xml导入数据库成功!");
} catch (Exception e) {
e.printStackTrace();
} finally {
ConnectionUtils.close(pst);
ConnectionUtils.close(pstmt);
ConnectionUtils.close(conn);
}
}
}
这是针对只有一个Bean,项目中我们是多条Bean进行解析。
传送至(二):
使用XStream解析复杂XML并插入数据库(一)的更多相关文章
- 使用XStream解析复杂XML并插入数据库(二)
标注黄色地方:我需要加深学习!!! 我写的是webservice,目前具体写webservice的步骤我还不清楚, 整理完小知识开始整理webservice! 针对以下格式的XML进行解析 <? ...
- python3.4.3 调用http接口 解析response xml后插入数据库
工作中需要调用一个http的接口,等不及java组开发,就试着用python去调用.Python版本3.4.3 完整的流程包括:从sqlServer取待调用的合同列表 -> 循环调用http接口 ...
- 分30条依次解析xml并插入数据库成功
package xxx; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import or ...
- xStream解析生成xml文件学习资料
参考链接: http://www.cnblogs.com/hoojo/archive/2011/04/22/2025197.html
- 我也来学着写写WINDOWS服务-解析xml抓取数据并插入数据库
项目告一段落,快到一年时间开发了两个系统,一个客户已经在试用,一个进入客户测试阶段,中间突然被项目经理(更喜欢叫他W工)分派一个每隔两小时用windows服务去抓取客户提供的外网xml,解析该xml, ...
- Ajax实现xml文件数据插入数据库(一)--- 构建解析xml文件的js库
Ajax实现将xml文件数据插入数据库的过程所涉及到的内容比较多,所以对于该过程的讲解本人打算根据交互的过程将其分为三个部分,第一部分为构建解析xml文件的javascript库,第二部分为ajax与 ...
- Ajax实现xml文件数据插入数据库(二)--- ajax实现与jsp的数据交互。
在上一篇文章中我们成功得到了重新组织后的数据,接下来需要做的便是将数据插入到数据库中了.在与数据库打交道的过程中有一些方法是普遍的,我们将这些通用方法封装到一个DbUtil类中,以便复用,封装好的Db ...
- (转载)XML解析之-XStream解析
转载来源:http://hwy584624785.iteye.com/blog/1168680 本例使用XStream生成一个xml文件,再发序列化xml文件内容. XStream是一个简单的类库,可 ...
- php操作xml并插入到数据库中
php操作xml并插入到数据库中 <? php header('content-type:text/html;charset=utf-8'); mysql_connect('localhost' ...
随机推荐
- Django框架详细介绍---Admin后台管理
1.Admin组件使用 Django内集成了web管理工具,Django在启动过程中会执行setting.py文件,初始化Django内置组件.注册APP.添加环境变量等 # Application ...
- 解决SVN提交和更新代码冲突?
解决冲突有三种选择: 1.放弃自己的更新,使用svn revert(回滚),然后提交.在这种方式下不需要使用svn resolved(解决) 2.放弃自己的更新,使用别人的更新.使用最新获取的版本覆盖 ...
- Go语言代码规范指导
本规范旨在为日常Go项目开发提供一个代码的规范指导,方便团队形成一个统一的代码风格,提高代码的可读性,规范性和统一性.本规范将从命名规范,注释规范,代码风格和 Go 语言提供的常用的工具这几个方面做一 ...
- Javascript在使用import 与export 区别及使用
一.import与export的用法 1.import的几种用法 import defautName from 'modules.js'; import { export } from 'module ...
- C++隐藏任务栏图标
在VC编程中,有时候我们需要将我们的程序在任务栏上的显示隐藏起来,我试过几种方法,下面我介绍一下我知道的三种方法. 第一种方法是设置窗口WS_EX_TOOLWINDOW扩展样式,通过在OnInitDi ...
- CentOS与Win7远程桌面互通
在CentOS上装上Rdesktop即可连接Windows,如下命令,第一次执行时报错,提示CredSSP required by server. [root@localhost ~]# rdeskt ...
- MyBatis笔记(一) 最简单的select
小白学习MyBatis的第一天,学习资料包括MyBatis3的官方文档,以及孤傲苍狼大佬的博客.这里先致敬大佬. · 首先,什么是MyBatis? 引用官网的一段话,“MyBatis 是一款优秀的持久 ...
- 2019/4/16 wen 反射与JVM
- telnet客户端操作memcached增删改查
一,通过telnet连接进入memcached(telnet 本地ip/服务器ip 端口) 进入后回车看效果: 二, 添加数据和取出数据 添加命令: add key名 0(固定) ...
- 010 Editor Mac安装教程
010 Editor mac版是mac上一款非常强大的十六进制编辑器,可以帮助用户进行编辑十六进制和二进制,可选择自己需要的进制进行编辑,还可对任何的文件进行编辑:软件内置了强大的模块.脚本操作,只需 ...