MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Générer un PDF avec la bibliothèque JasperReports et MongoDB

L'utilisation de JRBeanCollectionDataSource n'est pas la bonne façon d'utiliser le connecteur MongoDB. Jetez un œil à ce test fourni avec la source du connecteur Jaspersoft MongoDB :

MongoDbDatasource/src/test/java/com/jaspersoft/mongodb/ReportTest.java

Le connecteur binaire et la source se trouvent sur la page du projet .

Pour garder cette réponse autonome, voici un extrait de code montrant comment remplir un rapport MongoDB. C'est un extrait modifié du fichier que j'ai mentionné ci-dessus.

String mongoURI = "mongodb://bdsandbox6:27017/test";
MongoDbConnection connection = null;
Map<String, Object> parameters = new HashMap<String, Object>();
try {
  connection = new MongoDbConnection(mongoURI, null, null);
  parameters.put(MongoDbDataSource.CONNECTION, connection);
  File jasperFile;
  jasperFile = new File("MongoDbReport.jasper");
  JasperCompileManager.compileReportToFile("MongoDbReport.jrxml", "MongoDbReport.jasper");
  JasperFillManager.fillReportToFile("MongoDbReport.jasper", parameters);
  JasperExportManager.exportReportToPdfFile("MongoDbReport.jrprint");
}
} catch (Exception e) {
  e.printStackTrace();
} finally {
  if (connection != null) {
    connection.close();
  }
}