2011-07-25 53 views
1

我已經用hibernate創建了一個新的derby數據庫。我能夠在Apache derby中創建數據庫。我能夠從xml中的節點獲取數據並存儲它在arraylist中。我知道如何將arraylist contant傳遞給數據庫類。如何將arraylist傳遞到java中的數據庫

xml.java

 public class xml_read { 

    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(); 

    // System.out.println("Root element :" + doc.getDocumentElement().getNodeName()); 
    NodeList nList = doc.getElementsByTagName("device"); 
    // System.out.println("-----------------------"); 

for (int temp = 0; temp < nList.getLength(); temp++) { 

    Node nNode = nList.item(temp);  
    if (nNode.getNodeType() == Node.ELEMENT_NODE) { 

    Element eElement = (Element) nNode; 
    ArrayList arrayList = new ArrayList(); 

    //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); 
     System.out.println("type : " + getTagValue("type",eElement)); 
     System.out.println("Name : " + getTagValue("name",eElement)); 
     System.out.println("Set up : " + getTagValue("setup",eElement)); 


    } 
    } 
     } 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

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(); 
    } 


     } 

我需要到ArrayList值傳遞給設備class.Can任何一個可以幫助我如何將價值傳遞給設備類

+0

爲什麼不遍歷ArrayList並將值設置爲Device類? – BOSS

回答

1

如果您使用集合類型(例如,在您的情況下設置),則必須指定此集合如何映射到另一個數據庫表。所以在你的對象中它是一個可直接訪問的子對象集合,但是在你的數據庫中,它仍然被分成2個表格,它們的關係是1:n或n:m。

如果使用JPA,只需指定在註釋的關係:

​​

在JPA 2.0,你甚至可以避免指定的情況下,一個獨立的實體,您只使用基本類型:

@[email protected](name="item") 
@Column(name="name") 
private List<String> items; 
相關問題