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

Persistance des données Java Discussion :

Exploitation des données de BD en java


Sujet :

Persistance des données Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Février 2009
    Messages
    93
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 93
    Par défaut Exploitation des données de BD en java
    Bonjour,

    J'ai des données stockées dans une base de données Mysql et je cherche à implémenter une méthode java pour récupérer les données de la base et avoir en sortie ces données sous forme d"une structure java.
    (cette structure peut contenir des attributs qui correspondent à ceux de la table de la base).
    y a t-il qqn qui peut m'aider?

    A+.

  2. #2
    Membre expérimenté
    Profil pro
    Ingénieur informatique
    Inscrit en
    Avril 2006
    Messages
    166
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur informatique

    Informations forums :
    Inscription : Avril 2006
    Messages : 166
    Par défaut
    Salut,

    Je me suis créé une classe pour pouvoir exploiter ma db MySQL mais je récupère en sortie un Vector<Vector<String>> mais pas de structure tel que tu le voudrais...

    Bon ça vaut ce que ça vaut ...

    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
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
     
    import java.sql.*;
    import java.util.Vector;
     
     
    /**
     *
     * @author Jules
     */
    public class database
    {
        Connection con;
    	ResultSet res;
    	Statement stmt;
     
    	public String connectToBdd() throws ClassNotFoundException
    	{
            String resu = null;
    		try
    		{
                Class.forName("com.mysql.jdbc.Driver");
     
    			con = DriverManager.getConnection("jdbc:mysql://localhost/esales?user=j2ee&password=jsp");
                resu = "Success!";
    		}
    		catch (SQLException evt)
    		{
    			System.err.println("==>SQL Exception 1 :\n");
    			while(evt!=null)
    			{
                    resu = evt.getMessage();
    				System.out.println("Message: "+ evt.getMessage());
    				System.out.println("SQLState: "+ evt.getSQLState());
    				System.out.println("ErrorCode: "+ evt.getErrorCode());
    				evt = evt.getNextException();
    				System.out.println("");
    			}
    		}
            return resu;
    	}
     
    	public void closeBdd()
    	{
    		try
    		{
    			con.close();
    		}
    		catch (SQLException evt)
    		{
    			System.err.println("==>SQL Exception 2 :\n");
    			while(evt!=null)
    			{
    				System.out.println("Message: "+ evt.getMessage());
    				System.out.println("SQLState: "+ evt.getSQLState());
    				System.out.println("ErrorCode: "+ evt.getErrorCode());
    				evt = evt.getNextException();
    				System.out.println("");
    			}
    		}
    	}
     
    	public Vector<Vector<String>> getData(Vector<String> fields) //get data from resultset and put it into Vector<Vector<String>>
    	{
    		int nbFields = 0;
    		int i = 0,pos = 0;
    		boolean test = true;
    		Vector<String> row = new Vector<String>();
    		Vector<Vector<String>> tab = new Vector<Vector<String>>();
     
    		nbFields = fields.size();
     
            try
    	    {
     
                res.first();
     
    		    while (test)
    		    {
                    row = new Vector<String>();
                    for (i=0;i<nbFields;i++)
    			    {
                        pos = res.findColumn(fields.elementAt(i));
    			    	row.add(res.getString(pos));
    			    }
     
    			    tab.add(row);
     
    			    test = res.next();
    		    }
    		}
            catch(SQLException evt)
    		{
     
    		}
    		return tab;
    	}
     
    	public String SelectCount(String tab,String WhereField,String num) throws SQLException
    	{
    		//Declarations
    		String req = null;
    		String result = null;
     
    		//Execute request
    		stmt = con.createStatement();
     
    		req = "SELECT COUNT(*) FROM " + tab + " WHERE " + WhereField + " = " + num + ";";
    		stmt.execute(req);
     
    		//Get request result
    		res = stmt.getResultSet();
     
    		res.first();
     
    		result = res.getString(1);
     
    		return result;
    	}
     
    	public Vector<Vector<String>> Select(String tab,Vector<String> SelField,String WhereField,String arg) throws SQLException
    	{
    		//Declarations
    		String req, FSel = null;
    		Vector<Vector<String>> result = null;
    		int i = 0;
     
    		//Format string for request
    		FSel = SelField.elementAt(0);
    		for (i=1;i<SelField.size();i++)
    		{
    			FSel = FSel + "," + SelField.elementAt(i);
    		}
     
    		//Execute request
    		stmt = con.createStatement();
     
    		req = "SELECT " + FSel + " FROM " + tab + " WHERE " + WhereField + " = " + arg + ";";
    		System.out.println(req); //TODO
    		res = stmt.executeQuery(req);
     
    		//Get request Result
    		result = getData(SelField);
     
    		return result;
    	}
     
    	public Vector<Vector<String>> SelectAll(String tab,Vector<String> SelField) throws SQLException
    	{
    		//Declarations
    		String req, FSel = null;
    		Vector<Vector<String>> result = null;
    		int i = 0;
     
    		//Format string for request
    		FSel = SelField.elementAt(0);
    		for (i=1;i<SelField.size();i++)
    		{
    			FSel = FSel + "," + SelField.elementAt(i);
    		}
     
    		//Execute request
    		stmt = con.createStatement();
     
    		req = "SELECT " + FSel + " FROM " + tab + ";";
    		res = stmt.executeQuery(req);
     
    		//Get request Result
    		result = getData(SelField);
     
    		return result;
    	}
    	public void InsertInto(String tab,Vector<String>values) throws SQLException
    	{
    		String req = null;
    		String Fval = null;
    		int i = 0;
     
     
    		//Format string for request
    		Fval = "\"" + values.elementAt(0);
    		for (i=1;i<values.size();i++)
    		{
    			Fval = Fval + "\",\"" + values.elementAt(i);
    		}
    		Fval = Fval + "\"";
     
    		//Execute request
    		stmt = con.createStatement();
     
    		req = "INSERT INTO " + tab + " VALUES (" + Fval + ");";
    		System.out.println(req); //TODO rem comm
    		stmt.execute(req);
    	}
     
    	public void Delete (String tab, String WhereField, String num) throws SQLException
    	{
    		String req = null;
     
    		stmt = con.createStatement();
     
    		req = "DELETE FROM " + tab + " WHERE " + WhereField + " = " + num + ";";
    		stmt.execute(req);
     
    	}
     
    	public void Update (String tab, String field, String newValue, String Wherefield, String num) throws SQLException
    	{
    		String req = null;
     
    		stmt = con.createStatement();
     
    		req = "UPDATE " + tab + " SET " + field + "=" + newValue + " WHERE " + Wherefield + " = " + num + ";";
    		stmt.execute(req);
    	}
    }

  3. #3
    Membre expérimenté Avatar de Torg666
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2008
    Messages
    230
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2008
    Messages : 230
    Par défaut
    Heu.. utiliser un Vector<Vector<String> c'est pas très joyeux en terme de performance, a la limite une ArrayList<Arraylist<String>> mais là y a carrement mieux, utilise le ResultSet directement. Tu as tout ce qu'il faut, au niveau du ResultSet, pour avoir tes info et plus (nom de colonne, fonction de recherche,...) enfin à moins que tu soit limité à l'usage de certaine librairie (comme par exemple avec le framework GWT), le ResultSet c'est quand meme le mieux. Je t'invite donc à regarder la doc la dessus. Au début, ca à peut être l'air d'être assez rude, mais on s'appercoit que c'est quand même plus facile à utiliser qu'un ArrayList/Vector et surtout plus sûre...

Discussions similaires

  1. Exploitation des données de BD en java
    Par m3allem001 dans le forum JDBC
    Réponses: 9
    Dernier message: 11/03/2009, 22h17
  2. Exploitation des données de BD en java
    Par m3allem001 dans le forum Général Java
    Réponses: 3
    Dernier message: 11/03/2009, 10h24
  3. [MySQL] Lire et exploiter des données blob
    Par jamespage dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 20/11/2008, 17h44
  4. Réponses: 4
    Dernier message: 14/12/2007, 19h14
  5. Générer des données en C ou java pour MySQL?
    Par stef06 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 11/07/2006, 22h41

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