数据库映射库

时间:2012-10-03 20:23:14

标签: java android sqlite

我正在使用Jackson将JSON数据(我从Internet服务器检索)映射到应用程序对象(例如Artist,Clip,Playlist)。大多数情况下数据是静态的,因此我不需要过度加载 - 所以我想将它存储在数据库中。我需要一个类似于Jackson的映射器,它将解析数据库输出并为我构建对象(例如Artist,Clip,Playlist)。有没有?

感谢。

2 个答案:

答案 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);
}

}