One way to solve this problem using the below solution.
You can use object-relationship mapping (ORM) technique (Example As Hibernate, TopLink) for mapping database table to Java Object.
For parsing from Java Object to JSON Object , you can use either JAXB annotation.
JaxB Annotation Class and Marshal Example as below.
JaxB Annotation Java Example
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;
}
}
Marshaling Example
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);
}
}