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 :

Selection inverse dans un DB


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Par défaut Selection inverse dans un DB
    Messieurs-dames, bonsoir,

    Je suis en train de développer une petite application pour mon entreprise. Jusque là tout va bien, Java je m'y remet (depuis 4 ans d'absence) tout doucement, et jusqu'ici (touchons du bois) tout va bien.
    Excepté un truc.
    Je vais devoir rechercher, dans une colonne de ma DB, des données qui n'y sont pas, et ca je ne vois pas du tout comment je dois faire.

    Je m'explique :

    J'ai une colonne, dans ma DB, avec des chiffres, tous différents, mais pas forcément successifs. J'ai besoin justement, de sortir les chiffres qui ne se trouvent pas dans la colonnes, ceux qui ne sont pas utilisés.
    J'utilise une classe Java qui me permet d'accéder à ma DB à partir d'autres classes.
    Je vois le principe de ma recherche, mais je ne vois pas comment la mettre en pratique.

    Si quelqu'un a la moindre idée à ce propos, je suis preneur.

    Et tant que j'y suis, mon NetBeans me dit que le show() est démodé, quelqu'un connait la new version de ce truc?

    D'avance merci.


  2. #2
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    230
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 230
    Par défaut
    pour show() regardes dans la javadoc tu auras surement une alternative. Utilise setVisible(true).

    En ce qui concerne ton autre problème je pense que c'est purement algorithmique.

    A ta place je sélectionnerais tous les numéro de ta colonne en faisant un tri croissant, puis je ferais une boucle allant du plus petit numéro au plus grand en incrémentant de un à chaque itération. A chaque fois que tu ne trouves pas un numéro bah tu le mets dans une liste à part.

    A la fin de la boucle tu auras ta liste de numéros non attribués

  3. #3
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,

    Citation Envoyé par Rastapwalu Voir le message
    J'ai une colonne, dans ma DB, avec des chiffres, tous différents, mais pas forcément successifs. J'ai besoin justement, de sortir les chiffres qui ne se trouvent pas dans la colonnes, ceux qui ne sont pas utilisés.
    Je ne pense pas que ce soit possible en SQL pure...

    Ce que tu peux faire c'est une select ordonné sur ces chiffres qui te retournera donc la liste des chiffres présent, et partir de 0 (par exemple) pour rechercher les absents...

    Cela pourrait donner ceci :
    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
    	// On recherche les différentes valeurs ordonnées
    	ResultSet rs = st.executeQuery("select distinct column from table order by colum");
    	try {
    		// On défini une valeur de départ :
    		int cursor = 0;
    		while (rs.next()) {
    			// Pour chaque valeur présente dans la base :
    			int value = rs.getInt("column");
    			// Et on boucle sur toutes les valeurs entre
    			// le curseur et la valeur retournée :
    			for (int i=cursor; i<value; i++) {
    				// TODO : la valeur 'i' n'est pas présente dans la base
    			}
    			// On incrémente le curseur avant de passer au suivant :
    			cursor = value + 1;
    		}
     
    	} finally {
    		rs.close();
    	}
    Pour chaque valeur retourné par le select, tu peut déterminer celles qui manque...

    Citation Envoyé par Rastapwalu Voir le message
    Et tant que j'y suis, mon NetBeans me dit que le show() est démodé, quelqu'un connait la new version de ce truc?
    S'il s'agit d'un composant graphique, cela doit surement être setVisible()... mais en général cette information est indiqué dans la documentation de la méthode déprécié

    a++

    [edit] grillé

  4. #4
    Membre averti
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Par défaut
    Tout d'abord merci pour ces réponses si rapides.
    Merci pour ce code, que je m'empresserai de tester demain, puisque ma journée est finie pour aujourd'hui

    Je vous tiens au jus.

    Bonne soirée

  5. #5
    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
    Citation Envoyé par Rastapwalu Voir le message
    Merci pour ce code, que je m'empresserai de tester demain, puisque ma journée est finie pour aujourd'hui
    Ha les fonctionnaires ...

  6. #6
    Membre averti
    Inscrit en
    Janvier 2005
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 38
    Par défaut
    Messieurs, je ne vous ai pas oublié, mais comme j'ai un autre p*$@&!§ de problème, je n'ai toujours pas pu tester ce code.

    Je poste toujours mon problème ici, en espérant que quelqu'un passe ici et entende mon appel à l'aide :

    J'ai un petit soft avec menu, sur chaque élément du menu, un écouteur. Ici, je cherche simplement à me déconnecter (la connexion marche), mais il me dit qu'il ne connait pas la variable 'co'. Pourtant cette dernière est déclarée juste avant (dans la connexion).
    Les fonctions connecter et deconnecter se trouvent dans une autre classe (accesgen).

    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
                if(e.getSource()==connexion)
                    try 
                    {
                        Connection co=AccesGen.connecter("cables","","");
                        JOptionPane.showMessageDialog(null, "Connection with the database : Successful","Connection OK",JOptionPane.INFORMATION_MESSAGE);
                    }
                    catch(SQLException sqle){
                        System.out.println("Erreur SQL : " + sqle);
                        JOptionPane.showMessageDialog(null, "Failed connection with the databse","ERROR",JOptionPane.ERROR_MESSAGE);
                    }
                if(e.getSource()==deconnexion)
                    try
                    {
                        AccesGen.deconnecter(co);
                        JOptionPane.showMessageDialog(null, "Disconnect from the database successful","Déconnection OK",JOptionPane.INFORMATION_MESSAGE);
                    }
    Si quelqu'un a une piste, je suis preneur, parce que là je ne vois pas ou j'ai fait l'erreur (meme si je sais qu'il y en a une ).

  7. #7
    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
    Ton objet Connection n'existe que dans le bloc try/catch ...

    Il faut que tu fasses comme ceci pour qu'il soit accessible ailleurs ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Connection co; // même s'il n'est pas initialisé, la référence est accessible dans le reste du programme (enfin dans tout ce bloc)
    try {
       co = ... // initialisation
    } catch ...
     
    try {
       // deconnexion, attention co peut être null
    } catch
    ...

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

Discussions similaires

  1. Selection distincte dans un dlookupcombobox
    Par Tyler Durden dans le forum Bases de données
    Réponses: 3
    Dernier message: 06/10/2005, 08h19
  2. Comment écrire en inverse dans un TListView ?
    Par aliwassem dans le forum Composants VCL
    Réponses: 1
    Dernier message: 16/09/2005, 17h42
  3. Selection listener dans JTable
    Par calypso dans le forum Composants
    Réponses: 3
    Dernier message: 02/08/2004, 17h56
  4. Selection aléatoire dans une fouchette de 10%
    Par RobertDeNiroZ dans le forum Requêtes
    Réponses: 4
    Dernier message: 14/06/2004, 09h22
  5. [VB6] [Graphisme] Inversion dans picturebox
    Par tomnie dans le forum VB 6 et antérieur
    Réponses: 23
    Dernier message: 16/04/2003, 15h05

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