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 :

N'exécuter aucune requête si l'une échoue


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    68
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 68
    Points : 56
    Points
    56
    Par défaut N'exécuter aucune requête si l'une échoue
    salut les dev,

    j'utilise l'api JDBC pour manipuler ma bdd et j'ai un ensemble de requêtes à exécuter comme suit:

    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
    String sql="insert into Acte (nom, prenom,nom_Acte,depot,rdv,redactrice) values('"+nom1+"', '"+prenom1+"','"+Type+"','"+depot+"','"+rdv+"','"+redactrice+"')";
    		//System.out.println(sql);
    		Connection con=ConnectionManager.getConnection();
    		try {
    			Statement stmt=con.createStatement();
    			stmt.executeUpdate(sql);
    			sql="SELECT MAX(id) as max FROM Acte;";
    			ResultSet rs=stmt.executeQuery(sql);
    			rs.next();
    			String id=rs.getString(1);
    			sql="insert into location (idActe,duree,montant,banque,pret) values('"+id+"','"+duree+"','"+montant+"','"+banque+"','"+pret+"')";
    			stmt.executeUpdate(sql);
    			sql="insert into partie values('"+id+"','"+nom1+"','"+prenom1+"','1')";
    			stmt.executeUpdate(sql);
    			sql="insert into partie values('"+id+"','"+nom2+"','"+prenom2+"','2')";
    			stmt.executeUpdate(sql);
    			//System.out.println(sql);
    		} catch (SQLException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}
    Des fois ça m'arrive que la première requête s’exécute avec succès et les deux autre échouent.

    Comment je fais pour que soit toutes les requêtes s’exécutent avec succès, sinon, si l'une d'elle échoue, les autres ne font pas la mise à jour.

    Merci d'avance

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 711
    Points : 4 796
    Points
    4 796
    Par défaut
    Utilise les transactions
    http://java.developpez.com/faq/jdbc/...defTransaction

    Et puis, pendant que tu y es, utilises les PreparedStatement http://java.developpez.com/faq/jdbc/...paredStatement
    car ton code va planter à chaque fois qu'une apostrophe sera présente dans le nom
    ex : si le nom = "Valérie Giscard d'Estaing" -> alors paf ça plante ... mais pas pour des raisons politiques

    PreparedStatement gère automatiquement les problèmes d'apostrophe (entre autres)
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

Discussions similaires

  1. Réponses: 4
    Dernier message: 28/05/2012, 22h22
  2. [MySQL] Exécuter une requête UPDATE dans une boucle
    Par vacknov dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 24/10/2008, 17h46
  3. Exécution de variable paramètre dans une requête
    Par pascalourox dans le forum VBA Access
    Réponses: 2
    Dernier message: 20/10/2008, 14h07
  4. Exécuter une requête à partir d'une variable
    Par Poussy-Puce dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 16/03/2006, 14h15

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