Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/309.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java JaxB读取类层次结构_Java_Xml Parsing_Jaxb - Fatal编程技术网

Java JaxB读取类层次结构

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>

只是延伸问题。 要使用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>

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


您希望根据“NAME”属性为特定的实现类设置键,以便确定用于加载行数据的类?我尝试了这段代码,但得到异常
异常[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);
    }

}