Java JaxB读取类层次结构
只是延伸问题。 要使用JaxB读取以下xml文件吗Java JaxB读取类层次结构,java,xml-parsing,jaxb,Java,Xml Parsing,Jaxb,只是延伸问题。 要使用JaxB读取以下xml文件吗 <IMPORT> <TABLE NAME="USER"> <ROW> <USER_ID>1</USER_ID> <ROW_VERSION>1</ROW_VERSION> <USER_NAME>Navnath</USER_NAME>
<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>
1.
1.
纳夫纳特
纳夫纳特
纳夫纳特
2.
1.
昆巴
昆巴
昆巴
1.
工作1
1.
2.
工作2
1.
...
...
...
您可以在上面的xml文件中看到,每个表中的列名都不同。我想在数据库中插入此数据。我试图为此创建类层次结构,但我不知道如何做到这一点。我的ROW类将在每个表中包含不同的xml元素,这是我无法配置的区域。请提出建议。注意:我是专家组的负责人和成员 对于这个用例,您可以利用MOXy的
@xmlsdescriminatorNode
/@xmlsdescriminatorvalue
扩展(请参阅:)
导入
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;
}
UserTable
import org.eclipse.persistence.oxm.annotations.XmlDiscriminatorValue;
@XmlDiscriminatorValue("WORK")
public class WorkTable extends Table {
}
@xmlsdescriminatorvalue
注释用于指定与特定子类相对应的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;
}
工作台
import org.eclipse.persistence.oxm.annotations.XmlDiscriminatorValue;
@XmlDiscriminatorValue("WORK")
public class WorkTable extends Table {
}
jaxb.properties
要将MOXy指定为JAXB提供程序,您需要在与域模型相同的包中包含一个名为JAXB.properties
的文件,其中包含以下条目(请参阅:)
演示
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/Output
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;
}
下面是运行演示代码的输入和输出
1.
纳夫纳特
2.
昆巴
替代解决方案
或者,仅使用标准JAXB API,您可以使用XmlAdapter
异常[EclipseLink-3002](Eclipse持久性服务-2.3.0.v20110604-r9504):org.eclipse.persistence.exceptions.ConversionException异常描述:无法将类[class java.lang.String]的对象[]从映射[org.eclipse.persistence.oxm.mappings.XMLCompositeDirectCollectionMapping[ROW]]与描述符[XMLDescriptor(org.jaxb.UserTable-->[])转换为[class org.jaxb.UserRow]。在org.eclipse.persistence.exceptions.ConversionException.couldNotBeConverted(ConversionException.java:71)
@Navnath-您可以尝试使用EclipseLink 2.4.1:的代码吗。此外,如果您通过我的联系人软件包向我发送通知,我将通过电子邮件向您发送代码:
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);
}
}