IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JDBC Java Discussion :

Générer plusieurs fichiers JSON automatiquement


Sujet :

JDBC Java

  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Novembre 2013
    Messages : 37
    Points : 26
    Points
    26
    Par défaut Générer plusieurs fichiers JSON automatiquement
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    /*
     * 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 mongo;
     
    /**
     *
     * @author help
     */
    import java.awt.Component;
    import java.io.File;
    import java.io.FileWriter;
    import java.io.IOException;
    import java.sql.Array;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.logging.Level;
    import java.util.logging.Logger;
    import javax.swing.JFileChooser;
    import org.json.simple.JSONObject;
    public class json {
     
       public static void main(String[] args) throws InstantiationException, SQLException, IOException 
       {
          JSONObject obj = new JSONObject();
           try {
               Class.forName("com.mysql.jdbc.Driver").newInstance();
           } catch (IllegalAccessException ex) {
               Logger.getLogger(json.class.getName()).log(Level.SEVERE, null, ex);
           } catch (ClassNotFoundException ex) {
               Logger.getLogger(json.class.getName()).log(Level.SEVERE, null, ex);
           }
    	              Connection connect = DriverManager.getConnection("jdbc:mysql://localhost:3306/reseau_social","root","root"); 
    		      System.out.println("->Connecting to a selected database...");
    		      Statement stmt = connect.createStatement();
    /*************************************commune*************************************************/		    
                           ResultSet rs1 = stmt.executeQuery( "select id_user,u.nom, u.prenom, u.email, u.mot_de_pass,u.id_commune from user as u " ) ;
    	               ResultSetMetaData resultMeta = rs1.getMetaData();
     
             /*              
           JFileChooser fileChooser = new JFileChooser();
           fileChooser.setDialogTitle("Specify a file to save");    
           Component parentFrame = null;
     
    int userSelection = fileChooser.showSaveDialog(parentFrame);
     
    if (userSelection == JFileChooser.APPROVE_OPTION) {
                                File fileToSave = fileChooser.getSelectedFile();
                                System.out.println("Save as file: " + fileToSave.getAbsolutePath());
     
        */
      File file =new File ("C:\\Users\\help\\Desktop\\user.json") ;
                                file.createNewFile();
                                FileWriter writer =new FileWriter(file);
          while(rs1.next())
        { 
         // for(int i = 1; i <=  resultMeta.getColumnCount(); i++){
         // System.out.println("le"+rs1.getObject(2).toString());  
            obj.put("id_user", rs1.getObject(1).toString()) ;
            obj.put("nom", rs1.getObject(2).toString());
            obj.put("prenom", rs1.getObject(3).toString()) ;
            obj.put("email", rs1.getObject(4).toString());
             obj.put("mot_de_pass", rs1.getObject(5).toString()) ;
            obj.put("id_commune", rs1.getObject(6).toString());
              //System.out.println(obj);
            Object jsoncontent = obj;
            System.out.println("le"+jsoncontent);
            writer.write(jsoncontent.toString()+"\n");
            writer.flush();
                   // writer.close();
        }  rs1.close();    
     
       /**************************************************adress*****************************************/
        JSONObject obj1 = new JSONObject();
        ResultSet rs2 = stmt.executeQuery( "select * from adress " ) ;
        ResultSetMetaData	  resultMeta2 = rs2.getMetaData();
        File file1 =new File ("C:\\Users\\help\\Desktop\\adress.json") ;
        file.createNewFile();
        FileWriter writer1 =new FileWriter(file1);
        while(rs2.next())
        { 
            obj1.put("id_adress", rs2.getObject(1).toString()) ;   // for(int i = 1; i <=  resultMeta.getColumnCount(); i++){
            obj1.put("nom_adress", rs2.getObject(2).toString());
            Object jsoncontent1 = obj1;
            System.out.println("le"+jsoncontent1);
            writer1.write(jsoncontent1.toString()+"\n");
            writer1.flush();
            }  rs2.close();                                       // writer.close();
     
     
     
     /*************************************commune****************************************************************/                      
          JSONObject obj3 = new JSONObject();
        ResultSet rs3 = stmt.executeQuery( "select * from commune " ) ;
        ResultSetMetaData	  resultMeta3 = rs3.getMetaData();
        File file3 =new File ("C:\\Users\\help\\Desktop\\commune.json") ;
        file3.createNewFile();
        FileWriter writer3 =new FileWriter(file3);
        while(rs3.next())
        { 
            obj3.put("id_commune", rs3.getObject(1).toString()) ;   // for(int i = 1; i <=  resultMeta.getColumnCount(); i++){
            obj3.put("nom_commune", rs3.getObject(2).toString());
             obj3.put("id_adress", rs3.getObject(3).toString());
            Object jsoncontent3 = obj3;
            System.out.println("le"+jsoncontent3);
            writer3.write(jsoncontent3.toString()+"\n");
            writer3.flush();
            }  rs3.close();                                       // writer.close();
     
     
     
     
     
     
     
       }}
    ce scripts permet de recupérer les données de mes tables de la base de données et l'enregistre dans un fichier json . mais mon probleme c'est que ma base de donnée contients plus de 20 tables .donc j'arrive pas à générer des fichiers automatiquement sans creer l'un apres l'autre

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Si tu veux recupérer le contenu de chaque table dans un json, tu peux utiliser getMetadata() sur le ResultSet, les méthodes getColumnCount et getColumnLabel te permettront de déterminer le nom de le nombre de colonnes dans ton résultat.

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Novembre 2013
    Messages : 37
    Points : 26
    Points
    26
    Par défaut plus detaill
    s'il vous plait plus de detail si c'est possible un petit code source qu'explique mieu pour que je comprendre bien

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Tu voudrais pouvoir générer un json que pour un seul objet, ou une sélection d'objets, c'est ça ?

    Déjà, tu devrais découper la méthode main en plusieurs méthodes, une par table. Ensuite, itilise un paramètre pour ton programme, que tu peux récupérer par le tableau args[].

    Par exemple, chaque paramètre est le nom de l'objet :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    public static void main(String[] args) {
       if ( args.length==0 ) {
          exportAll();
       }
       else {
          try(Connection connect = creerConnection()) {
             for(String arg : args) {
     
                switch( arg ) {
                  case "user":
                      exportUser(connect);
                      break;
                   case "commune":
                      exportCommune(connect);
                      break;
                   case...
                }
             }
          }
       }
    }
     
    public static void exportAll() {
         try(Connection connect = creerConnection() {
             exportUser(connect);
             exportCommune(connect);
             ...
         }
     }
     
    ...
    [EDIT]Je n'avais pas vu que tu avais déjà posé la même question dans une autre discussion et qu'on t'avait déjà répondu.

    Ce que suggère @Tchize_, c'est de traiter génériquement chaque objet, au lieu d'avoir une méthode spécifique.

    Avec ResultSetMetadata metadata = ResultSet.getMetaData(); tu peux connaitre la liste de champs récupérés et leur type, donc en bouclan dessus, tu peux traiter tous les objets dans une seule méthode. Quelque chose comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    public static void exportObject(Connection connection, String objectName) throws SQLException, IOException {
     
       try(Writer writer = Files.newBufferedWriter(Paths.get("C:\\Users\\help\\Desktop\\"+objectName+".json"))) {	
           try(Statement statement = connection.createStatement()) {
    	   ResultSet rs = statement.executeQuery("select * from "+objectName);
    	   ResultSetMetaData metadata = rs.getMetaData();
    	   while (rs.next()) {
    	       JSONObject jsoncontent = new JSONObject();
    	       for(int i=1; i<=metadata.getColumnCount(); i++) {
     
    		      String name = metadata.getColumnName(i);
    		      jsoncontent.put(name, rs.getObject(i).toString()) ;
     
    	       }
     
    	       writer.write(jsoncontent.toString());
    	       writer.write(System.lineSeparator());
     
               }
          }
       }			
    }
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [AC-97] Générer plusieurs fichiers Word depuis un Etat.
    Par cacoubalboa dans le forum IHM
    Réponses: 4
    Dernier message: 20/07/2010, 09h51
  2. Réponses: 8
    Dernier message: 14/06/2010, 13h38
  3. Générer un fichier json
    Par hjulius dans le forum Format d'échange (XML, JSON...)
    Réponses: 1
    Dernier message: 30/04/2010, 13h43
  4. [AJAX] recupérer plusieur fichiers JSON
    Par Emcy dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 04/10/2007, 14h41
  5. Générer plusieurs fichiers à partir d'un fichier excel
    Par yas2006 dans le forum Documents
    Réponses: 3
    Dernier message: 02/06/2006, 17h54

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo