[英]JaxB to read class hierarchy
只是使用JaxB問題擴展了解析類的層次結構 。 想要使用JaxB讀取以下xml文件
<IMPORT>
<TABLE NAME="USER">
<ROW>
<USER_ID>1</USER_ID>
<ROW_VERSION>1</ROW_VERSION>
<USER_NAME>Navnath</USER_NAME>
<LOGIN>Navnath</LOGIN>
<LOGIN_PASSWORD>Navnath</LOGIN_PASSWORD>
</ROW>
<ROW>
<USER_ID>2</USER_ID>
<ROW_VERSION>1</ROW_VERSION>
<USER_NAME>Kumbhar</USER_NAME>
<LOGIN>Kumbhar</LOGIN>
<LOGIN_PASSWORD>Kumbhar</LOGIN_PASSWORD>
</ROW>
</TABLE>
<TABLE NAME="WORK">
<ROW>
<WORK_ID>1</WORK_ID>
<WORK_NAME>Work1</WORK_NAME>
<ROW_VERSION TYPE="N">1</ROW_VERSION>
</ROW>
<ROW>
<WORK_ID>2</WORK_ID>
<WORK_NAME>Work2</WORK_NAME>
<ROW_VERSION TYPE="N">1</ROW_VERSION>
</ROW>
</TABLE>
<TABLE> ... </TABLE>
<TABLE> ... </TABLE>
<TABLE> ... </TABLE>
</IMPORT>
您可以在上面的xml文件中看到每個表中的列名都不同。 我想將此數據插入數據庫中。 我試圖為此創建類層次結構,但是我不知道該怎么做。 我的ROW類將在每個表中包含不同的xml元素,而這是我無法配置的區域。 請提出建議。
注意:我是EclipseLink JAXB(MOXy)的負責人,並且是JAXB(JSR-222)專家組的成員。
您可以在此用例中利用MOXy的@XmlDescriminatorNode
/ @XmlDescriminatorValue
擴展名(請參閱: http : @XmlDescriminatorValue
)。
進口
import java.util.List;
import javax.xml.bind.annotation.*;
@XmlRootElement(name="IMPORT")
@XmlAccessorType(XmlAccessType.FIELD)
public class Import {
@XmlElement(name="TABLE")
private List<Table> tables;
}
表
@XmlDescriminatorNode
批注用於指定XML屬性,該屬性將用於指示將實例化哪個子類。 JAXB實現無法通過反射@XmlSeeAlso
類的子類,我們將使用@XmlSeeAlso
批注來引用它們。
import javax.xml.bind.annotation.XmlSeeAlso;
import org.eclipse.persistence.oxm.annotations.XmlDiscriminatorNode;
@XmlDiscriminatorNode("@NAME")
@XmlSeeAlso({UserTable.class, WorkTable.class})
public abstract class Table {
}
用戶表
@XmlDescriminatorValue
批注用於指定與特定子類相對應的NAME
屬性的值。
import java.util.List;
import javax.xml.bind.annotation.*;
import org.eclipse.persistence.oxm.annotations.XmlDiscriminatorValue;
@XmlDiscriminatorValue("USER")
@XmlAccessorType(XmlAccessType.FIELD)
public class UserTable extends Table {
@XmlElement(name="ROW")
private List<UserRow> rows;
}
UserRow
import javax.xml.bind.annotation.XmlElement;
public class UserRow {
@XmlElement(name="USER_ID")
private int userID;
@XmlElement(name="USER_NAME")
private String userName;
}
工作表
import org.eclipse.persistence.oxm.annotations.XmlDiscriminatorValue;
@XmlDiscriminatorValue("WORK")
public class WorkTable extends Table {
}
jaxb.properties
要將MOXy指定為JAXB提供程序,您需要在與域模型相同的程序包中包含一個名為jaxb.properties
的文件,並帶有以下條目(請參閱: http : //blog.bdoughan.com/2011/05/specifying-eclipselink- moxy-as-your.html )。
javax.xml.bind.context.factory=org.eclipse.persistence.jaxb.JAXBContextFactory
演示
import java.io.File;
import javax.xml.bind.*;
public class Demo {
public static void main(String[] args) throws Exception {
JAXBContext jc = JAXBContext.newInstance(Import.class);
Unmarshaller unmarshaller = jc.createUnmarshaller();
File xml = new File("src/forum15741264/input.xml");
Import result = (Import) unmarshaller.unmarshal(xml);
Marshaller marshaller = jc.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.marshal(result, System.out);
}
}
input.xml中/輸出
以下是運行演示代碼的輸入和輸出。
<?xml version="1.0" encoding="UTF-8"?>
<IMPORT>
<TABLE NAME="USER">
<ROW>
<USER_ID>1</USER_ID>
<USER_NAME>Navnath</USER_NAME>
</ROW>
<ROW>
<USER_ID>2</USER_ID>
<USER_NAME>Kumbhar</USER_NAME>
</ROW>
</TABLE>
<TABLE NAME="WORK"/>
</IMPORT>
替代解決方案
或者,僅使用標准的JAXB API,您可以使用XmlAdapter
嘗試以下方法
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.