我可以使用以下代码读取XML文件。我需要知道如何使用arraylist将xml添加到设备数据库。
Xml代码:
public static void main(String argv[]) {
try {
File fXmlFile = new File("c:\\testing.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fXmlFile);
doc.getDocumentElement().normalize();
NodeList nList = doc.getElementsByTagName("device");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
ArrayList<Device> arrayList = new ArrayList<Device>();
//System.out.println(arrayList);
String type=getTagValue("type", eElement);
String Name=getTagValue("name", eElement);
String Setup=getTagValue("setup", eElement);
arrayList.add(type);
arrayList.add(Name);
arrayList.add(Setup);
System.out.println(arrayList);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
private static String getTagValue(String sTag, Element eElement){
NodeList nlList= eElement.getElementsByTagName(sTag).item(0).getChildNodes();
Node nValue = (Node) nlList.item(0);
return nValue.getNodeValue();
}
}
Device.java
import java.util.HashSet;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.OneToMany;
import javax.persistence.Table;
@Entity
@Table(name = "DEVICE")
public class Device {
private String type;
private String setup;
private String name;
private Long deviceId;
private Set<CommandInfo> commandSet = new HashSet<CommandInfo>();
public Device() {
}
public Device(String name, String type, String setup) {
System.out.println("name = "+name+" type = "+type+" setup = "+setup);
this.name = name;
this.type = type;
this.setup = setup;
}
/**
* @return the type
*/
public String getType() {
return type;
}
/**
* @param type the type to set
*/
public void setType(String type) {
this.type = type;
}
/**
* @return the setup
*/
public String getSetup() {
return setup;
}
/**
* @param setup the setup to set
*/
public void setSetup(String setup) {
this.setup = setup;
}
/**
* @return the name
*/
public String getName() {
return name;
}
/**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}
/**
* @return the id
*/
@Id
@GeneratedValue
@Column(name = "DEVICE_ID")
public Long getDeviceId() {
return deviceId;
}
/**
* @param id the id to set
*/
public void setDeviceId(Long id) {
this.deviceId = id;
}
/**
* @return the commandSet
*/
@OneToMany(cascade = CascadeType.ALL)
@JoinTable(name = "DEVICE_COMMAND", joinColumns = {
@JoinColumn(name = "DEVICE_ID") },
inverseJoinColumns = { @JoinColumn(name = "COMMAND_ID")
})
public Set<CommandInfo> getCommandSet() {
return commandSet;
}
/**
* @param commandSet the commandSet to set
*/
public void setCommandSet(Set<CommandInfo> commandSet) {
this.commandSet = commandSet;
}
/* (non-Javadoc)
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("Device [type=");
builder.append(type);
builder.append(", setup=");
builder.append(setup);
builder.append(", name=");
builder.append(name);
builder.append(", deviceId=");
builder.append(deviceId);
builder.append(", commandSet=");
builder.append(commandSet);
builder.append("]");
return builder.toString();
}
}
任何人都可以帮我解决如何在java中将这个xml对象添加到数据库中。提前谢谢。
答案 0 :(得分:1)
如果要将原始XML存储在数据库中,可以在byte[]
类中使用Device
属性。然后,将XML文档转换为字节数组并相应地存储它。如果你必须处理更大的文件,你也应该看看流式传输。