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 :

Somme sql entre deux dates


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    201
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2014
    Messages : 201
    Par défaut Somme sql entre deux dates
    Salut les développeurs,
    J’ai un petit problème avec une requête SQL, je vais me casser les dents dessus.
    J’ai une table Achat, contenant parmi autres deux colonnes (date et paiement). Quand je veux sommer les paiements entre une plage de date, si au moins l’une des deux dates des bords des plages existent dans ma table la somme est calculée normalement. Si les deux dates n’y figure pas une exception est générée. Voici ma petite voyelle de requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String query1 = "select  SUM (paiement) from Achat WHERE Achat.date between '"+( date )+"' and  '"+( date1 )+"'";
    Et voice l’exception:
    Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
    at vues.Paiement.jButton1ActionPerformed(Paiement.java:234)
    at vues.Paiement.access$300(Paiement.java:16)
    ………………
    Ça pointe vers:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println("  "+rsltSet.getObject(1).toString());
    Ou est ce que j’ai fauté??!

  2. #2
    Membre émérite Avatar de Cincinnatus
    Homme Profil pro
    Développeur d'applications métier
    Inscrit en
    Mars 2007
    Messages
    593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur d'applications métier
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2007
    Messages : 593
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println("  "+rsltSet.getObject(1).toString());
    ça peut être : (1) rsltSet.getObject(1) si rsltSet est null
    ou (2) rsltSet.getObject(1).toString() si le getObject(1) renvoie null.

    A vérifier, il faudra ajouter 2 lignes de log, tant qu'à faire, au lieu des System.out.println(...);
    Et le .toString() est le plus souvent facultatif. S'en passer peut éviter le cas de plantage n.2.

  3. #3
    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
    avoir du code un peu plus complet, histoire de voir ce que tu fais, et une stacktrace entière, ça aiderait à t'aider

  4. #4
    Membre très actif
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    201
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2014
    Messages : 201
    Par défaut
    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
            String s, s1;
            String J, M, A, A1;
            String date, date1;
            J = jj.getSelectedItem().toString();
            M = mm.getSelectedItem().toString();
            A = aa.getSelectedItem().toString();
            String t[] = A.split("");
            String aa;
            aa = "" + t[2] + "" + t[3];
            date = J + "/" + M + "/" + aa; //date debut
     
            J = jj1.getSelectedItem().toString();
            M = mm1.getSelectedItem().toString();
            A1 = aa1.getSelectedItem().toString();
     
            String t2[] = A1.split("");
            String aa1;
            aa1 = "" + t2[2] + "" + t2[3];
            date1 = J + "/" + M + "/" + aa1; //date fin
     
            String url = "jdbc:h2:./src/BD/BDH22";
            String login = "root";
            String password = "";
            Connection connection = null;
            Statement stmt = null;
            ResultSetMetaData rsltSetMeta = null;
     
            try {
                connection = DriverManager.getConnection(url, login, password);
            } catch (SQLException ex) {
                Logger.getLogger(Paiement.class.getName()).log(Level.SEVERE, null, ex);
            }
            System.out.println("c connecté pour ouvrir dossier");
            try {
                stmt = connection.createStatement();
     
     
            } catch (SQLException ex) {
                Logger.getLogger(Paiement.class.getName()).log(Level.SEVERE, null, ex);
            }
     
     
            String query1 = "select  SUM (paiement) from Achat WHERE Achat.date between '" + (date) + "' and  '" + (date1) + "'";
            ResultSet rsltSet = null;
            try {
                rsltSet = stmt.executeQuery(query1);
                rsltSetMeta = rsltSet.getMetaData();
     
            } catch (SQLException ex) {
                Logger.getLogger(Paiement.class.getName()).log(Level.SEVERE, null, ex);
            }
     
     
            try {
                while (rsltSet.next()) {
     
                    System.out.println(" ffffffffff " + rsltSet.getMetaData().getColumnCount());
                    for (int i = 1; i <= rsltSetMeta.getColumnCount(); i++) {
     
     
                        System.out.println("  " + rsltSet.getObject(1).toString());
                        this.c.setText(rsltSet.getObject(1).toString());  //ecriture dans mon interface
                    }
                }
            } catch (SQLException ex) {
                Logger.getLogger(Paiement.class.getName()).log(Level.SEVERE, null, ex);
     
            }
            c.setVisible(true);
            c.setEditable(false);
            da.setVisible(true);
    tchize_ voila le boutton de tout mon code
    Cincinnatus je n'ai pas compris!

  5. #5
    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
    Tu peux nous donner la méthode complète (de préférence en corrigeant ton indentation qu'on sache suivre) et la sortie complète de ta console. JE suspecte que tu as eu une exception juste avant le parcours du result set. Vu que tu continue quand même, tu te retrouve à parcourir un vieux ResultSet où la colonne 1 contient un null.

    D'une manière générale, quand tu as une exception, traite là. Juste l'afficher et continuer, c'est cacher le problème sous le tapis.

  6. #6
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 713
    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 713
    Par défaut
    Plusieurs choses qui polluent ton code :

    1) Pourquoi utiliser un A.split("") qui est inefficace dans le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
            A=aa.getSelectedItem().toString();       
            String t[]=A.split("");
            String aa;
            aa=""+t[2]+""+t[3];
    Cela fait que si dans aa.getSelectedItem().toString() a pour valeur "2017" alors aa = "17"
    Dans ce cas, il vaut mieux écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
            aa = getSelectedItem().toString().substring(2);
    2) En SQL c'est toujours mieux de nommer les colonnes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String query1 = "select  SUM (paiement) AS mon_total from Achat WHERE Achat.date between '"+( date )+"' and  '"+( date1 )+"'";
    3) Il n'est pas utile de recourir au ResultSetMetaData pour parcourir les colonnes du resultset vu qu'il n'y a qu'une seule colonne !
    d'autant plus inutile puisque tu écris dans la boucle rsltSet.getObject(1) ce qui fait que même s'il y avait eu plusieurs colonnes, tu ne lis que la première.

    Ensuite, cette requête SQL ne renvoie qu'une seule ligne (pas plus)
    Donc tu peux allègrement supprimer le while qui sert à parcourir les enregistrements quand il y en a plusieurs.

    Simplification du code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
            try {
                rsltSet.next()  // pour positionner sur le 1er et unique enregistrement
                System.out.println(rsltSet.getObject(1).toString());
                this.c.setText(rsltSet.getObject(1).toString());  //ecriture dans mon interface
     
            } catch (SQLException ex) {
                Logger.getLogger(Paiement.class.getName()).log(Level.SEVERE, null, ex);
     
            }
    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/

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

Discussions similaires

  1. [WD17] Requête SQL entre deux dates
    Par chrysaxel dans le forum WinDev
    Réponses: 9
    Dernier message: 27/01/2023, 23h40
  2. requete SQL entre deux dates
    Par Augustule dans le forum Requêtes
    Réponses: 2
    Dernier message: 01/10/2013, 13h01
  3. [SQL] Nombre de jours entre deux dates
    Par azeggouar dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 19/08/2009, 16h07
  4. [SQL] obtenir la différence en jours entre deux dates sql
    Par toma03 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 06/06/2007, 12h20
  5. [SQL Server] Sélection entre deux dates
    Par Gabrielly dans le forum Langage SQL
    Réponses: 3
    Dernier message: 21/06/2006, 14h51

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