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

avec Java Discussion :

Méthode modifier dans java


Sujet :

avec Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2015
    Messages : 24
    Par défaut Méthode modifier dans java
    Bonjour,

    Il s'agit d'une petite appli où l'utilisateur peut modifier les données du clients, ajouter, supprimer.
    Les méthodes ajouter et supprimer marchent, mais pour "modifier" ça ne fonctionne pas.
    J'ai beau chercher je ne comprends pas... Si quelqu'un a eu idée.. Merci beaucoup

    Classe avec les méthodes
    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
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    package com.jassur.dao;
    import java.sql.Date;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import javax.swing.JOptionPane;
    import com.jassur.model.Address;
    import com.jassur.model.Client;
    import com.mysql.jdbc.Statement;
    public class ClientDAO extends DAO<Client> {
    	@Override
    	public Client create(Client obj) {
    		String sql = 
     
    				"INSERT INTO clients "+
    				"(last_name, first_name, phone, email, business, created_at) "+
    				"VALUES (?, ?, ?, ?, ?, ?)";
    		try {
    			PreparedStatement statement = connect.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
    			statement.setString(1, obj.getLastName());
    			statement.setString(2, obj.getFirstName());
    			statement.setString(3, obj.getPhone());
    			statement.setString(4, obj.getEmail());
    			statement.setBoolean(5, obj.getBusiness());
    			statement.setDate(6, new Date(System.currentTimeMillis()));
    			int rowInserted = statement.executeUpdate();
    			if (rowInserted > 0) {
    				ResultSet generatedKeys = statement.getGeneratedKeys();
    					if (obj.getAddress() != null) {
    					if (generatedKeys.next()) {
    						/* Get the generated id for the client and set it */
    		                obj.setId(generatedKeys.getInt(1));
    		                obj.getAddress().setClientId(obj.getId());
    		                AddressDAO addressDAO = new AddressDAO();
    		                addressDAO.setConnect(connect);
    		                Address newAdd = addressDAO.create(obj.getAddress());
    		                obj.setAddress(newAdd);
    		            }
    				}
    				return obj;
    			}
    		} catch (SQLException e) {
    			e.printStackTrace();
    		}
    		return null;
    	}
     
    	@Override
    	public boolean delete(Client obj) {
     
    		String sql = "DELETE FROM clients WHERE id_client = "+obj.getId();
     
    		System.out.println("SQL REQUEST : "+sql);
     
    		try {
     
    			int result = this.connect.createStatement().executeUpdate(sql);
     
     
     
    			if (result > 0) {
     
    				return true;
     
    			}
     
    			return true;
     
    		} catch (Exception e) {
     
    			return false;
     
    		}
     
    	}
    	@Override
     
    	public Client update(Client obj) {
    		// TODO Auto-generated method stub
    		String sql = "UPDATE clients SET last_name = ?, first_name = ?, phone = ?, business = ?, email = ?"
    				+"WHERE id_client = "+obj.getId();
    		System.out.println("SQL REQUEST : "+sql);
    		try {
    			//int result = this.connect.createStatement().executeUpdate(sql, Statement.RETURN_GENERATED_KEYS);
     
    			PreparedStatement stateUpdate = connect.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
     
    			stateUpdate.setString(1,obj.getLastName());
     
    			stateUpdate.setString(2,obj.getFirstName());
     
    			stateUpdate.setString(3,obj.getPhone());
     
    			stateUpdate.setBoolean(4,obj.getBusiness());
     
    			stateUpdate.setString(5,obj.getEmail());
     
    			//stateUpdate.setString(5,obj.getCreatedAt());
     
    			stateUpdate.executeUpdate(sql);
     
    			stateUpdate.close();
     
    		//	JOptionPane.showMessageDialog(null, "Modification réalisée",
     
    					//"MODIFICATION", JOptionPane.INFORMATION_MESSAGE);
    			return obj;
     
    		} catch (Exception e) {
     
    			e.printStackTrace();
     
    			return null;
     
    		}
    	}
     
    	@Override
    	public Client find(int id) {
     
    		Client client = null;
    		try {
     
    			ResultSet result = this.connect.createStatement(
     
    					ResultSet.TYPE_SCROLL_INSENSITIVE,
     
    					ResultSet.CONCUR_READ_ONLY
     
    			).executeQuery(
     
    					"SELECT * "+
     
    				    "FROM clients INNER JOIN addresses ON clients.id_client = addresses.client_id "+
     
    					"WHERE clients.id_client = "+id+";");
     
     
     
    			if (result.first()) {
     
     
     
    				client = new Client();
    				client.setId(id);
     
    				client.setBusiness(result.getBoolean("business"));
     
    				client.setEmail(result.getString("email"));
     
    				client.setFirstName(result.getString("first_name"));
     
    				client.setLastName(result.getString("last_name"));
     
    				client.setPhone(result.getString("phone"));
    				Address address = new Address();
     
    				address.setCity(result.getString("city"));
     
    				address.setStreet(result.getString("street"));
     
    				address.setCountry(result.getString("country"));
     
    				address.setRegion(result.getString("region"));
     
    				address.setZip(result.getInt("zip"));
     
    				client.setAddress(address);
    			}
    		} catch (SQLException e) {
    			e.printStackTrace();
    		}
    		return client;
    	}
     
    	@Override
    	public ArrayList<Client> find() {
     
    		ArrayList<Client> clients = new ArrayList<Client>();
     
    		try {
     
    			ResultSet result = this.connect.createStatement(
     
    					ResultSet.TYPE_SCROLL_INSENSITIVE,
     
    					ResultSet.CONCUR_READ_ONLY
     
    			).executeQuery(
     
    					"SELECT * "+
     
    				    "FROM clients INNER JOIN addresses ON clients.id_client = addresses.client_id ");
     
    			if (result.first()) {
    				while (result.next()) {
     
    					Client client = new Client();
    					client.setId(result.getInt("id_client"));
     
    					client.setBusiness(result.getBoolean("business"));
     
    					client.setEmail(result.getString("email"));
     
    					client.setFirstName(result.getString("first_name"));
     
    					client.setLastName(result.getString("last_name"));
     
    					client.setPhone(result.getString("phone"));
     
    					Address address = new Address();
     
    					address.setCity(result.getString("city"));
     
    					address.setStreet(result.getString("street"));
     
    					address.setCountry(result.getString("country"));
     
    					address.setRegion(result.getString("region"));
     
    					address.setZip(result.getInt("zip"));
    					client.setAddress(address);
    					clients.add(client);
     
    				}		
     
    			}
     
    		} catch (SQLException e) {
     
    			e.printStackTrace();
     
    		}
     
    		return clients;
     
    	}
     
    }
    classe client
    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
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
     
    package com.jassur.model;
     
    import java.util.ArrayList;
     
     
    import org.json.simple.JSONObject;
     
     
    public class Client implements Model {
     
     
     
    	private int id = 0;
     
     
     
    	/*
     
    	 * Has one
     
    	 */
     
    	private Address address = null;
     
    private int addressId;
     
     
    	/*
     
    	 * Has many
     
    	 */
     
    	private ArrayList<Loan> loans;
     
     
     
    	/*
     
    	 * Attributes
     
    	 */
     
    	private String firstName = "";
     
    	private String lastName = "";
     
    	private String phone = "";
     
    private String email = "";
     
    private boolean business;
     
     
    	/*
     
    	 * Constructors
     
    	 */
     
    	public Client() {
     
    		// code ..
     
    }
     
     
    	public int getId() {
     
    		return id;
     
    	}
     
    	public void setId(int id) {
     
    		this.id = id;
     
    }
     
    	public Address getAddress() {
     
    		return address;
     
    	}
     
    	public void setAddress(Address address) {
     
    		this.address = address;
     
    }
     
     
    	public ArrayList<Loan> getLoans() {
     
    		return loans;
     
    	}
     
    	public void setLoans(ArrayList<Loan> loans) {
     
    		this.loans = loans;
     
    }
     
    public String getFirstName() {
     
    		return firstName;
     
    	}
     
    	public void setFirstName(String firstName) {
     
    		this.firstName = firstName;
     
    }
     
    public String getLastName() {
     
    		return lastName;
     
    	}
     
    	public void setLastName(String lastName) {
     
    		this.lastName = lastName;
     
    }
     
    public String getPhone() {
     
    		return phone;
     
    	}
     
    	public void setPhone(String phone) {
     
    		this.phone = phone;
     
    }
     
    	public String getEmail() {
     
    		return email;
     
    	}
     
    	public void setEmail(String email) {
     
    		this.email = email;
     
    	}
     
    	public boolean getBusiness() {
     
    		return business;
     
    	}
     
    	public void setBusiness(boolean business) {
     
    		this.business = business;
     
    	}
     
    	public int getAddressId() {
     
    		return addressId;
     
    	}
     
    	public void setAddressId(int addressId) {
     
    		this.addressId = addressId;
     
    	}
     
    	@Override
     
    	public JSONObject toJSON() {
     
     
     
    		JSONObject jObj = new JSONObject();
     
     
     
    		jObj.put("id_client", this.id);
     
    		jObj.put("first_name", this.firstName);
     
    		jObj.put("last_name", this.lastName);
     
    		jObj.put("phone", this.phone);
     
    		jObj.put("email", this.email);
     
    		jObj.put("business", this.business);
     
    		if (this.address != null) {
     
    			jObj.put("address", this.address.toJSON());
     
    		}
    		return jObj;
     
    	}
    	@Override
     
    	public void parseJSON(JSONObject jo) {
     
    		this.id = (int) (long)jo.get("id_client");
     
    		this.firstName = (String)jo.get("first_name");
     
    		this.lastName = (String)jo.get("last_name");
     
    		this.phone = (String)jo.get("phone");
     
    		this.email = (String)jo.get("email");
     
    		this.business = (boolean)jo.get("business");
     
     
     
    		if (jo.containsKey("address")) {
     
    			Address ad = new Address();
     
    			ad.parseJSON((JSONObject) jo.get("address"));
     
    			this.address = ad;
     
    		}
     
     
     
    	}
     
     
     
    }

  2. #2
    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 : 55
    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
    Billets dans le blog
    2
    Par défaut
    Salut,

    Citation Envoyé par artdream Voir le message
    ça ne fonctionne pas.
    Mais encore ? Qu'est-ce qu'il se passe ou ne se passe pas ? Y a-t-il une exception et laquelle ?
    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.

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2015
    Messages : 24
    Par défaut
    Au niveau de l'affichage :
    Je clique sur update
    Je modifie
    Je clique sur ok
    Retour aux infos des clients : rien n'a été modifié

    Au niveau d'éclipse on dirait qu'il ne prend pas en compte les nouvelles valeurs dans la console.

    Je vous fais un screen d'eclipse dès que je peux.

    merci beaucoup

  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 : 55
    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
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par artdream Voir le message
    Retour aux infos des clients : rien n'a été modifié
    "infos de clients" ? C'est-à-dire ? Tu fais un select pour vérifer et tu ne vois pas les modifications, ou c'est une fenêtre de ton application avec le client affiché ? Parce que dans ce cas, il faut mettre à jour la fenêtre après l'update.

    Citation Envoyé par artdream Voir le message
    Au niveau d'éclipse on dirait qu'il ne prend pas en compte les nouvelles valeurs dans la console.
    Qu'est-ce Eclipse vient faire dans l'histoire ? C'est parce que tu utilises le Data Source Explorer pour consulter ta base ? C'est pareil : il faut rafraîchir.
    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.

  5. #5
    Membre chevronné Avatar de freddou17
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2013
    Messages
    341
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2013
    Messages : 341
    Par défaut
    Slt,

    Dans le code ci-dessous il ne manquerait pas espace (email=?) ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    String sql = "UPDATE clients SET last_name = ?, first_name = ?, phone = ?, business = ?, email = ?"
    				+"WHERE id_client = "+obj.getId();
    Edit: pourquoi ne pas binder obj.getId() alors que le reste des paramètres l'est?
    ++

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

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    executeUpdate te retourne le nombre de row modifiés. Commence déjà par vérifier que cette valeur est bien 1. Si elle est 0 c'est que ton id n'existe pas dans la db.

Discussions similaires

  1. Générer (en code JAVA) la méthode equals dans les classes bindées par JAXB2
    Par greatmaster1971 dans le forum Format d'échange (XML, JSON...)
    Réponses: 0
    Dernier message: 11/12/2013, 16h55
  2. [JDOM] Modifier un fichier XML dans java avec JDOM
    Par FatmaFafa dans le forum Format d'échange (XML, JSON...)
    Réponses: 10
    Dernier message: 24/07/2012, 15h44
  3. [PROPERTIES] Bug dans java.util.Properties ?
    Par mathieu dans le forum Collection et Stream
    Réponses: 6
    Dernier message: 28/04/2004, 15h11
  4. Comment generer un fichier war dans java
    Par relivio dans le forum ANT
    Réponses: 4
    Dernier message: 12/03/2004, 13h43

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