我正在使用Jackson将JSON数据(我从Internet服务器检索)映射到应用程序对象(例如Artist,Clip,Playlist)。大多数情况下数据是静态的,因此我不需要过度加载 - 所以我想将它存储在数据库中。我需要一个类似于Jackson的映射器,它将解析数据库输出并为我构建对象(例如Artist,Clip,Playlist)。有没有?
感谢。
答案 0 :(得分:1)
您正在寻找的是ORM(对象关系映射)库。在this post中对ORM解决方案进行了很好的讨论。
答案 1 :(得分:1)
使用以下解决方案解决此问题的一种方法。
您可以使用对象关系映射(ORM)技术(Example As Hibernate,TopLink)将数据库表映射到Java Object。 要从Java Object解析为JSON Object,可以使用JAXB批注。 JaxB Annotation Class和Marshal示例如下。
JaxB Annotation Java示例
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement
public class UserJaxB {
private String name;
private String id;
public UserJaxB() {
}
@XmlElement(name = "id")
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
@XmlElement(name = "name")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
封送示例
import java.io.*;
import javax.xml.bind.*;
import javax.xml.stream.XMLStreamWriter;
import org.codehaus.jettison.mapped.*;
public class MarshalDemo {
public static void main(String[] args) throws JAXBException {
JAXBContext jc = JAXBContext.newInstance(UserJaxB.class);
Unmarshaller unmarshaller = jc.createUnmarshaller();
UserJaxB userJaxB = new UserJaxB();
userJaxB.setId("123");
userJaxB.setName("ravi");
Configuration config = new Configuration();
MappedNamespaceConvention con = new MappedNamespaceConvention(config);
Writer writer = new OutputStreamWriter(System.out);
XMLStreamWriter xmlStreamWriter = new MappedXMLStreamWriter(con, writer);
Marshaller marshaller = jc.createMarshaller();
marshaller.marshal(userJaxB, xmlStreamWriter);
}
}