Arrays en documentos con Mongodb con JGMongo
Un documento en MongoDB, es una estructura compuesta por pares (key, value).
En esta ocasión mostrare como manejar Arrays de documentos mediante jgmongo https://github.com/avbravo/jgmongo Un framework que estoy desarrollando para MongoDB
y el documento sedes:
@Getter
@Setter
public class Sedes extends GenericBeans {
@Id
@SerializedName("Idsede")
private String idsede;
@SerializedName("Sede")
private String sede;
@SerializedName("Paises")
private List<Paises> paises;
Para almacenar los datos en la colección desde Java usamos:
Agregamos el repositorio:
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>com.github.avbravo</groupId>
<artifactId>jgmongo</artifactId>
<version>0.9</version>
</dependency>
</dependencies>
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package com.utica.mavenproject1q.entity;
import com.google.gson.annotations.SerializedName;
import com.jgmongo.anotaciones.Id;
import com.jgmongo.services.GenericBeans;
import lombok.Getter;
import lombok.Setter;
import org.bson.Document;
/**
*
* @author avbravo
*/
@Getter
@Setter
public class Paises extends GenericBeans {
@Id
@SerializedName("Siglas")
private String siglas;
@SerializedName("Pais")
private String pais;
@SerializedName("Logo")
private String logo;
public Document toDocument(Paises paises) {
Document doc = new Document();
try {
doc = Document.parse(getGson().toJson(paises));
} catch (Exception e) {
System.out.println("toDocument() " + e.getLocalizedMessage());
}
return doc;
}
public Paises toPojo(Document doc) {
Paises paises = new Paises();
try {
paises = (Paises) fromJsontoPojo(doc.toJson(), new Paises().getClass());
} catch (Exception e) {
System.out.println("toPojo() " + e.getLocalizedMessage());
}
return paises;
}
@Override
public String toString() {
return "Paises{" + "siglas=" + siglas + ", pais=" + pais + '}';
}
}
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package com.utica.mavenproject1q.entity;
import com.google.gson.annotations.SerializedName;
import com.jgmongo.anotaciones.Id;
import com.jgmongo.services.GenericBeans;
import java.util.List;
import lombok.Getter;
import lombok.Setter;
import org.bson.Document;
/**
*
* @author avbravo
*/
@Getter
@Setter
public class Sedes extends GenericBeans {
@Id
@SerializedName("Idsede")
private String idsede;
@SerializedName("Sede")
private String sede;
@SerializedName("Paises")
private List<Paises> paises;
public Document toDocument(Sedes sedes) {
Document doc = new Document();
try {
doc = Document.parse(getGson().toJson(sedes));
} catch (Exception e) {
System.out.println("toDocument() " + e.getLocalizedMessage());
}
return doc;
}
public Sedes toPojo(Document doc) {
Sedes sedes = new Sedes();
try {
sedes = (Sedes) fromJsontoPojo(doc.toJson(), new Sedes().getClass());
} catch (Exception e) {
System.out.println("toPojo() " + e.getLocalizedMessage());
}
return sedes;
}
@Override
public String toString() {
return "Sedes{" + "idsede=" + idsede + ", sede=" + sede + '}';
}
}
import com.jgmongo.persistence.AbstractFacade;
import com.mongodb.MongoClient;
import com.utica.mavenproject1q.entity.Paises;
/**
*
* @author avbravo
*/
public class PaisesFacade extends AbstractFacade<Paises>{
public PaisesFacade( ){
super(Paises.class, "fantasy", "paises");
}
@Override
protected MongoClient getMongoClient() {
MongoClient mongoClient = new MongoClient();
return mongoClient;
}
}
import com.jgmongo.persistence.AbstractFacade;
import com.mongodb.MongoClient;
import com.utica.mavenproject1q.entity.Sedes;
/**
*
* @author avbravo
*/
public class SedesFacade extends AbstractFacade<Sedes>{
public SedesFacade( ){
super(Sedes.class, "fantasy", "sedes");
}
@Override
protected MongoClient getMongoClient() {
MongoClient mongoClient = new MongoClient();
return mongoClient;
}
}
// TODO code application logic here
try {
PaisesFacade paisesFacade = new PaisesFacade();
SedesFacade sedesFacade = new SedesFacade();
List<Paises> list = new ArrayList<>();
list = paisesFacade.findAll();
if (!list.isEmpty()) {
Sedes sedes = new Sedes();
sedes.setIdsede("s-1");
sedes.setSede("Sede 1");
sedes.setPaises(list);
sedesFacade.save(sedes);
}
} catch (Exception e) {
System.out.println("error " + e.getLocalizedMessage());
}
}
Resultado
Proyecto de ejemplo que implementa la funcionalidad
https://github.com/avbravo/jgmongodesktopexample
Un documento en MongoDB, es una estructura compuesta por pares (key, value).
En esta ocasión mostrare como manejar Arrays de documentos mediante jgmongo https://github.com/avbravo/jgmongo Un framework que estoy desarrollando para MongoDB
Documentos de Paises y Sedes.
Tenemos dos colecciones: paises con información como esta:
@Getter
@Setter
public class Paises extends GenericBeans {
@Id
@SerializedName("Siglas")
private String siglas;
@SerializedName("Pais")
private String pais;
@SerializedName("Logo")
private String logo;
y el documento sedes:
@Getter
@Setter
public class Sedes extends GenericBeans {
@Id
@SerializedName("Idsede")
private String idsede;
@SerializedName("Sede")
private String sede;
@SerializedName("Paises")
private List<Paises> paises;
Para almacenar los datos en la colección desde Java usamos:
Agregamos el repositorio:
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>com.github.avbravo</groupId>
<artifactId>jgmongo</artifactId>
<version>0.9</version>
</dependency>
</dependencies>
Creamos los Entity
Paises.java
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package com.utica.mavenproject1q.entity;
import com.google.gson.annotations.SerializedName;
import com.jgmongo.anotaciones.Id;
import com.jgmongo.services.GenericBeans;
import lombok.Getter;
import lombok.Setter;
import org.bson.Document;
/**
*
* @author avbravo
*/
@Getter
@Setter
public class Paises extends GenericBeans {
@Id
@SerializedName("Siglas")
private String siglas;
@SerializedName("Pais")
private String pais;
@SerializedName("Logo")
private String logo;
public Document toDocument(Paises paises) {
Document doc = new Document();
try {
doc = Document.parse(getGson().toJson(paises));
} catch (Exception e) {
System.out.println("toDocument() " + e.getLocalizedMessage());
}
return doc;
}
public Paises toPojo(Document doc) {
Paises paises = new Paises();
try {
paises = (Paises) fromJsontoPojo(doc.toJson(), new Paises().getClass());
} catch (Exception e) {
System.out.println("toPojo() " + e.getLocalizedMessage());
}
return paises;
}
@Override
public String toString() {
return "Paises{" + "siglas=" + siglas + ", pais=" + pais + '}';
}
}
Sedes.java
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package com.utica.mavenproject1q.entity;
import com.google.gson.annotations.SerializedName;
import com.jgmongo.anotaciones.Id;
import com.jgmongo.services.GenericBeans;
import java.util.List;
import lombok.Getter;
import lombok.Setter;
import org.bson.Document;
/**
*
* @author avbravo
*/
@Getter
@Setter
public class Sedes extends GenericBeans {
@Id
@SerializedName("Idsede")
private String idsede;
@SerializedName("Sede")
private String sede;
@SerializedName("Paises")
private List<Paises> paises;
public Document toDocument(Sedes sedes) {
Document doc = new Document();
try {
doc = Document.parse(getGson().toJson(sedes));
} catch (Exception e) {
System.out.println("toDocument() " + e.getLocalizedMessage());
}
return doc;
}
public Sedes toPojo(Document doc) {
Sedes sedes = new Sedes();
try {
sedes = (Sedes) fromJsontoPojo(doc.toJson(), new Sedes().getClass());
} catch (Exception e) {
System.out.println("toPojo() " + e.getLocalizedMessage());
}
return sedes;
}
@Override
public String toString() {
return "Sedes{" + "idsede=" + idsede + ", sede=" + sede + '}';
}
}
Creamos los Facade
PaisesFacade.java
import com.jgmongo.persistence.AbstractFacade;
import com.mongodb.MongoClient;
import com.utica.mavenproject1q.entity.Paises;
/**
*
* @author avbravo
*/
public class PaisesFacade extends AbstractFacade<Paises>{
public PaisesFacade( ){
super(Paises.class, "fantasy", "paises");
}
@Override
protected MongoClient getMongoClient() {
MongoClient mongoClient = new MongoClient();
return mongoClient;
}
}
SedesFacade.java
import com.jgmongo.persistence.AbstractFacade;
import com.mongodb.MongoClient;
import com.utica.mavenproject1q.entity.Sedes;
/**
*
* @author avbravo
*/
public class SedesFacade extends AbstractFacade<Sedes>{
public SedesFacade( ){
super(Sedes.class, "fantasy", "sedes");
}
@Override
protected MongoClient getMongoClient() {
MongoClient mongoClient = new MongoClient();
return mongoClient;
}
}
Programa Principal
public static void main(String[] args) {// TODO code application logic here
try {
PaisesFacade paisesFacade = new PaisesFacade();
SedesFacade sedesFacade = new SedesFacade();
List<Paises> list = new ArrayList<>();
list = paisesFacade.findAll();
if (!list.isEmpty()) {
Sedes sedes = new Sedes();
sedes.setIdsede("s-1");
sedes.setSede("Sede 1");
sedes.setPaises(list);
sedesFacade.save(sedes);
}
} catch (Exception e) {
System.out.println("error " + e.getLocalizedMessage());
}
}
Resultado
Proyecto de ejemplo que implementa la funcionalidad
https://github.com/avbravo/jgmongodesktopexample
Comments