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 :

Numéro de la ligne insérer


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Avatar de Kalite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2006
    Messages : 310
    Par défaut Numéro de la ligne insérer
    Bonjour,

    voila mon problème, je fai une insértion dans la table1 qui possède un champ de type serial (je suis sur un base postgresql et je fai un programme en java) ensuite je fai une insertion dans une table de jointure, la table 2, dont la clé primaire est une composé de deux clés etrangères dont l'une est celle de la table1. Le problème est de savoir comment faire l'insertion dans les deux table alors que je ne connai pas la valeur de la colonne sérial.

    comment pourrai je faire ?

  2. #2
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    Ben montre nous un peu de code parce que là c'est pas vraiment clair.

    Enfin tout simplement tu as deux solution je pense :

    1. Tu insères la valeur Serial dans la table 1 donc tu connais la valeur
    2. Tu fais un select imbriqué lors de la deuxième insertion pour récupérer la valeur du serial.


    Mais bon à mon avis c'est la solution 1 qu'il te faut. A moins que tu n'insère pas la valeur serial. Dans ce cas tu ne peux pas insérer dans table2

  3. #3
    Membre éclairé
    Avatar de Kalite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2006
    Messages : 310
    Par défaut
    sérial c'est une valeur auto incrémenter sur postgresql.

    voila mon modèle conceptuel de donnée et mon problème se trouve avec la tbldoon et la table tbloperation.
    Nom : base GED.JPG
Affichages : 142
Taille : 76,4 Ko

  4. #4
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    Ben à part passer par un select dans la table operation pour récupérer la valeur du serial je vois pas comment tu peux t'en sortir ...

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 504
    Par défaut
    salut,


    peut etre que ça va d'aider:

    d'abord il faur créer dans la classe 2 variable static de type entier pour prendre les
    le numero de serie le static sert à conserver les informations

    ensuite il faut que tu puisse faire une requete pour transmettre ton numero de serie
    il te faut obligatoirement une donnée de ta table exemple pour mon code le nom de l'entreprise.

    et ainsi de suite .
    apres tu peux inserer les données dans ta table.

    voici mon code :

    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
    String SQLE="SELECT identreprise FROM Entreprise WHERE nomentreprise='"+Text_Entreprise.getText()+"'";
     
    				Statement st =connect.createStatement();
    				ResultSet res =st.executeQuery(SQLE);
     
    				if (res.next())
    				{
    					idEntreprise=res.getInt("identreprise");
    				}
     
    				System.out.println(Text_Categorie.getText());
    				String Sql="SELECT idcategorie FROM Categorie WHERE nomcategorie='"+Text_Categorie.getText()+"'";
     
    				;
    			   res =st.executeQuery(Sql);
     
    				if (res.next())
    				{
    					idCategorie=res.getInt("idcategorie");
    				}
    				System.out.println("ok");
    				Vscategorie.clear();
    				String sql="INSERT INTO Souscategorie (idsouscategorie,identreprise,idcategorie,nomsouscategorie,imagesouscategorie) VALUES (NULL,"+
    				idEntreprise+","+idCategorie+",'"+creerscategorie.getText()+"','"+image.getText()+"')";
     
    				java.sql.PreparedStatement pr = connect.prepareStatement(sql);
    				pr.executeUpdate(sql);
     
    				System.out.println("Insersion reussi !!");

Discussions similaires

  1. Réponses: 7
    Dernier message: 06/06/2006, 16h40
  2. [TMemo] Obtenir le numéro de la ligne
    Par JFM dans le forum Composants VCL
    Réponses: 3
    Dernier message: 03/08/2005, 20h06
  3. [Exceptions] Comment afficher le numéro de la ligne ?
    Par hpalpha dans le forum Langage
    Réponses: 2
    Dernier message: 09/12/2004, 09h58
  4. [xml] Récupérer le numéro de la ligne d'erreur d'un fichier
    Par ZoumZoumMan dans le forum C++Builder
    Réponses: 7
    Dernier message: 20/03/2004, 19h09
  5. ListBox : récupération du numéro de la ligne
    Par Argonz dans le forum C++Builder
    Réponses: 2
    Dernier message: 26/11/2003, 08h17

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