2011-07-25 75 views
0

我能夠使用以下代碼讀取XML文件。我需要知道如何使用arraylist將xml添加到設備數據庫。使用java中的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(); 
    } 


    } 

誰能幫助我如何該XML對象在java中.Thanks提前添加到數據庫中。

+0

順便說一句:你應該改變你的問題,並描述你真正需要什麼。 – home

回答

1

如果要將原始XML存儲在數據庫中,則可以在Device類中使用byte[]屬性。然後,將XML文檔轉換爲字節數組並相應地存儲它。如果你必須處理更大的文件,你也應該看流媒體。

+0

還是你想只保留已提取的屬性?如果是這樣,你必須獲得一個EntityManager,創建一個Device實例並堅持它。 – home

+0

不,我不想將原始文件添加到設備類。我想要每個節點的內容到設備類。 – bharathi

+0

是的,所以你必須獲得一個EntityManager,存在大量的教程:http://download.oracle.com/docs/cd/B31017_01/web.1013/b28221/usclient005.htm#CIHIAHIE – home

相關問題