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

XML/XSL et SOAP Discussion :

Consommer un web service SOAP/XML


Sujet :

XML/XSL et SOAP

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut Consommer un web service SOAP/XML
    Bonjour,
    Je suis actuellement entrain de réaliser un projet de calcul de statistiques sous forme d'un web service sous axis 2 (SOAP...)

    J'en suis arrivé à générer mon web service via NetBeans en .wsdl (bien la galère quand on connait pas).

    Je peux le voir et y accéder via Axis 2, donc je suppose qu'il fonctionne

    Mon problème actuel réside dans l'utilisation de mon web service, j'aimerai via une IHM (HTML/JSP), si j'ai bien compris le principe, accéder au fichier XML de mon web service.

    J'ignore totalement où il se trouve ni comment l'utiliser ... ?_?

    Merci d'avance.

  2. #2
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Salut,

    Pour te faciliter la vie, tu peux utiliser un environnement de développement (Netbeans, Eclipse...). Il te suffit alors de demander la création d'un client Webservice. L'outil va alors te demander l'adresse (l'url) du fichier WSDL et il l'utilisera pour générer toutes les classes nécessaires qu'il te suffira d'instancier (c'est l'objet même du fichier WSDL, fournir toutes les infos du webservice).

    ERE

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Est ce intégré dans NeatBeans ou faut il utiliser soapUI ?

  4. #4
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Citation Envoyé par wifsimster Voir le message
    Est ce intégré dans NeatBeans ou faut il utiliser soapUI ?
    Regarde par exemple ici il y a tous les cas de figure qui t'intéressent

    ERE

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Merci beaucoup

    J'ai réussit à mettre place un client JSP, mais j'ai encore une erreur avec le client JAVA.

    J'espère corriger ça, merci encore

  6. #6
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Alors après avoir bien lu les exemples j'arrive correctement à créer et utiliser un Web Service ainsi qu'un Client via NetBeans !

    Seulement lorsque j'essaye d'implémenter mon Web service j'ai un problème au Build.

    Voici le code d'erreur que le compilateur me retourne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Created dir: C:\Users\irist\Documents\NetBeansProjects\BpelModule1Test\MoteurStatistiquesWSApplication\build\generated\wsgen\service
    Created dir: C:\Users\irist\Documents\NetBeansProjects\BpelModule1Test\MoteurStatistiquesWSApplication\build\generated\wsgen\service\resources
    Created dir: C:\Users\irist\Documents\NetBeansProjects\BpelModule1Test\MoteurStatistiquesWSApplication\build\generated\wsgen\binaries
    wsgen-MoteurStatistiques:
    C:\Users\irist\Documents\NetBeansProjects\BpelModule1Test\MoteurStatistiquesWSApplication\nbproject\jaxws-build.xml:18: Error starting wsgen: 
    BUILD FAILED (total time: 2 seconds)
    J'ai allégé mon code dans le Web service pour trouvé d'où venait mon erreur...

    J'arrive donc à écrire ceci sans erreur :

    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
    package org.me.moteurStatistiques;
     
    import javax.jws.WebService;
    import java.sql.*;
     
    @WebService()
    public class MoteurStatistiques {
     
        Connection con;
     
    //-------------------------------------------------------
    // Initialisation du driver OBCD.
    //-------------------------------------------------------
     
    public void Database(String Driver)
    {
        try
        {
            // Driver JDBC
            Class.forName(Driver);
        }
        catch(Exception e)
        {
            System.out.println("Erreur lors du chargement du driver:"+ e.getMessage());
        }
    }
     
    //-------------------------------------------------------
    // Connection à la base de données.
    //-------------------------------------------------------
     
    public void Open(String url,String login,String password)
    {
        try
        {
            con = DriverManager.getConnection(url,login,password);
        }
        catch(Exception e)
        {
            System.out.println("echec d'ouverture:"+e.getMessage());
        }
    }
     
    //-------------------------------------------------------
    // Fermeture de la connection à la base de données.
    //-------------------------------------------------------
     
    public void Close()
    {
        try
        {
            con.close();
        }
        catch(Exception e)
        {
            System.out.println("echec lors de la fermeture:"+e.getMessage());
        }
    }
    }
    Or lorsque je rajoute cette méthode dans le Web service j'obtiens l'erreur ci-dessus :

    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
    //-------------------------------------------------------
    // Exécution d'une requête type.
    //-------------------------------------------------------
     
    public ResultSet Execute(String sql)
    {
        ResultSet r = null;
        try
        {
            Statement stmt = con.createStatement();
            r = stmt.executeQuery(sql);
        }
        catch(Exception e)
        {
            System.out.println(e.getMessage());
        }
        return r;
    }

  7. #7
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Cela ne m'étonne pas trop car le Resultset n'est pas un type standard. Il ne faut pas oublier que les webservices ne sont pas consommés uniquement en Java. Je te conseille de regarder plutôt pour renvoyer une structure XML, et tu peux le faire simplement en passant par un objet de type webrowset et appeler la methode writeXML.

    ERE

  8. #8
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Je me douté bien qu'il y avait quelque chose qui cloché avec le Resultset.

    Merci pour cette aide, une fois de plus

    Je me penche dessus !

  9. #9
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Bonjour,

    Me revoilà, j'ai parcouru pas mal de documentation sur les RowSet et particulièrement WebRowSet pour essayer de mettre en place un exemple fonctionnel.

    J'en suis arrivé là :

    Mon JAVA :
    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
    public String ExecuteXML() throws SQLException, IOException
    {
        WebRowSet rowset = new WebRowSetImpl();
     
        StringWriter sw = new StringWriter();
     
        String xmlString = new String();
     
        rowset.setCommand("SELECT COUNT(*) FROM inscription WHERE id_service = 2;");
     
        rowset.execute();
     
        rowset.writeXml(sw);
     
        xmlString = sw.toString();
     
        sw.close();
     
        return xmlString;
    }
    Mon JSP:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <%
                String toto = null;
                toto = db.ExecuteXML();
    %>
            Service : <%= toto %>
    Erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    org.apache.jasper.JasperException: An exception occurred processing JSP page /base.jsp at line 72
     
    69: <%
    70:             //Récupération des différents services sur la base de données.
    71:             String toto = null;
    72:             toto = db.ExecuteXML();
    73: %>
    74: 
    75:         Service : <%= toto %>

  10. #10
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Salut,

    Lis la FAQ concernant la manipulation d'un WebRowset, et notamment le fait qu'il faut passer les infos de connexion à la base

    ERE

  11. #11
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Je ne suis pas arriver à les mettre en application ~~

    Je pense pouvoir arriver à faire sens pour le moment.

    Seulement je ne comprend toujours pas ce qu'il faut ou ne faut pas pour compiler mon web service.

    J'essaie de le faire par étape et de voir ce qui le dérange mais là ...

    Ce code passe à la compilation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    private double tauxInscriptionService(int service) throws SQLException
    {
        double taux = 0;
        double nbrPI = 0;
        double nbrI = 0;
     
        nbrPI = new Double(NombrePotentielIncrit(service));
        nbrI = new Double(NombreInscrit(service));
     
        taux = (nbrI / nbrPI)*100;
     
        return taux;
    }
    Alors que je voudrais pouvoir utiliser ma fonction donc la mettre en public :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    public double tauxInscriptionService(int service) throws SQLException
    {
        double taux = 0;
        double nbrPI = 0;
        double nbrI = 0;
     
        nbrPI = new Double(NombrePotentielIncrit(service));
        nbrI = new Double(NombreInscrit(service));
     
        taux = (nbrI / nbrPI)*100;
     
        return taux;
    }
    Et ceci ne passe pas !

  12. #12
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Qu'as tu comme message d'erreur lors de la compilation ?

    ERE

  13. #13
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Désolé !

    Erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    wsgen-MoteurStatistiques:
    C:\Users\irist\Documents\NetBeansProjects\BpelModule1Test\MoteurStatistiquesServeur\nbproject\jaxws-build.xml:18: Error starting wsgen: 
    BUILD FAILED (total time: 2 seconds)

  14. #14
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Bonjour,

    J'ai repris l'essentiel du projet pour me refaire à mon but premier . . .

    J'arrive donc toujours ici lors de la compilation du service :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    wsgen-MoteurStatistiques:
    C:\Users\irist\Documents\NetBeansProjects\BpelModule1Test\MoteurStatistiquesServeur\nbproject\jaxws-build.xml:18: Error starting wsgen: 
    BUILD FAILED (total time: 2 seconds)
    Je n'arrive pas à voir ce qui provoque l'arrêt de wsgen ???

  15. #15
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Utilises tu encore un type de retour de fonction dédié à Java ?

    ERE

  16. #16
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Voici la structure :



    A moins que String soit particulier à Java (ce qui n'est pas le cas) je ne vois pas . ..

  17. #17
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    A moins que String soit particulier à Java (ce qui n'est pas le cas)
    Effectivement !

    ERE

  18. #18
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Effectivement String est particulier à Java ou effectivement non, ce qui ne m'aide pas vraiment ~~

  19. #19
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Par défaut
    Citation Envoyé par wifsimster Voir le message
    Effectivement String est particulier à Java ou effectivement non, ce qui ne m'aide pas vraiment ~~
    Effectivement String n'est pas particulier à Java, donc le souci provient d'autre chose

    Tu peux envoyer le code complet de ta classe ?

    ERE

  20. #20
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2008
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2008
    Messages : 34
    Par défaut
    Voici :

    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
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    package Mypackage;
     
    import javax.jws.WebService;
    import java.sql.*;
     
    @WebService()
    public class MoteurStatistiques
    {
        Connection con;
     
    //-------------------------------------------------------
    // Initialisation du driver OBCD.
    //-------------------------------------------------------
     
    public void Database(String Driver)
    {
        try
        {
            Class.forName(Driver);
        }
        catch(Exception e)
        {
            System.out.println("Erreur lors du chargement du driver:"+ e.getMessage());
        }
    }
     
    //-------------------------------------------------------
    // Connection à la base de données.
    //-------------------------------------------------------
     
    public void Open(String url,String login,String password)
    {
        try
        {
            con = DriverManager.getConnection(url,login,password);
        }
        catch(Exception e)
        {
            System.out.println("echec d'ouverture:"+e.getMessage());
        }
    }
     
    //-------------------------------------------------------
    // Fermeture de la connection à la base de données.
    //-------------------------------------------------------
     
    public void Close()
    {
        try
        {
            con.close();
        }
        catch(Exception e)
        {
            System.out.println("echec lors de la fermeture:"+e.getMessage());
        }
    }
     
    //-------------------------------------------------------
    // Calcul du taux d'inscrit par service.
    //-------------------------------------------------------
     
    private int NombrePotentielIncrit(int service) throws SQLException
    {
        int nbrInscritP = 0;
     
        String sql =
        "SELECT COUNT(ID_usager) AS nb_inscription_potentielle " +
        "FROM usager, service WHERE (Age_min_service<=ROUND(DATEDIFF(NOW(),Date_naissance)/365.25,0)" +
        "<=Age_max_service) AND ID_service=" + service + ";";
    
        Statement stmt = con.createStatement();
        ResultSet r = stmt.executeQuery(sql);
    
        while(r.next())
        {
            nbrInscritP = Integer.parseInt(r.getString(1));
        }
    
        return nbrInscritP;
    }
    
    private int NombreInscrit(int service) throws SQLException
    {
        int nbrInscrit = 0;
    
        String sql = "SELECT COUNT(*) FROM inscription WHERE id_service = " + service + ";";
        Statement stmt = con.createStatement();
        ResultSet r = stmt.executeQuery(sql);
    
        while(r.next())
        {
            nbrInscrit = Integer.parseInt(r.getString(1));
        }
    
        return nbrInscrit;
    }
    
    public String tauxInscriptionService(int service) throws SQLException
    {
        double taux = 0;
        double nbrPI = 0;
        double nbrI = 0;
    
        nbrPI = new Double(NombrePotentielIncrit(service));
        nbrI = new Double(NombreInscrit(service));
    
        taux = (nbrI / nbrPI)*100;
    
        String s = format(taux,2,1);
    
        return s;
    }
    
    //-------------------------------------------------------
    // Fonction de formatage de Double au centième.
    //-------------------------------------------------------
    
    static final String ZEROES = "000000000000";
    static final String BLANKS = "            ";
    
    static String format( double val, int n, int w)
    {
    	double incr = 0.5;
    	for( int j=n; j>0; j--) incr /= 10;
    	val += incr;
     
        String s = Double.toString(val);
    	int n1 = s.indexOf('.');
    	int n2 = s.length() - n1 - 1;
     
    	if (n>n2)      s = s+ZEROES.substring(0, n-n2);
    	else if (n2>n) s = s.substring(0,n1+n+1);
     
    	if( w>0 & w>s.length() ) s = BLANKS.substring(0,w-s.length()) + s;
    	else if ( w<0 & (-w)>s.length() )
        {
            w=-w;
    		s = s + BLANKS.substring(0,w-s.length()) ;
        }
     
        return s;
    }
     
    //------------------------------------------------------------------
    // Fonction de calcul du Taux de personnes ayant réglé la cantine.
    //------------------------------------------------------------------
     
    private int NombreInscritRegles() throws SQLException
    {
        int nbrInscritR = 0;
     
        String sql = "SELECT COUNT(*) FROM inscription, inscription_usager " +
                "WHERE inscription.ID_inscription_usager= inscription_usager.ID_inscription_usager " +
                "AND YEAR( Date_paiement_periode ) = YEAR( Date_dernier_paiement ) " +
                "AND (MONTH( Date_dernier_paiement ) = MONTH( Date_paiement_periode ) " +
                "OR (MONTH( Date_dernier_paiement )-1) = MONTH( Date_paiement_periode )) " +
                "AND (01 <= DAY( Date_dernier_paiement ) <= 03) AND ID_service = 5;";
    
        Statement stmt = con.createStatement();
    
        ResultSet r = stmt.executeQuery(sql);
    
        while(r.next())
        {
            nbrInscritR = Integer.parseInt(r.getString(1));
        }
    
        return nbrInscritR;
    }
    
    public String tauxPaiementsCantineRegles() throws SQLException
    {
        double taux = 0;
        double nbrI = 0;
        double nbrIR = 0;
    
        nbrI = new Double(NombreInscrit(5));
    
        nbrIR = new Double(NombreInscritRegles());
    
        taux = (nbrIR / nbrI)*100;
    
        String s = format(taux,2,1);
    
        return s;
    }
    
    //------------------------------------------------------------------
    // Fonction de calcul du Taux de personnes étant en retard pour
    // le paiment de la cantine.
    //------------------------------------------------------------------
    
    public String tauxPaiementsCantineRetard() throws SQLException
    {
        double taux = 0;
        double nbrI = 0;
        double nbrIR = 0;
        double nbrINR = 0;
    
        nbrI = new Double(NombreInscrit(5));
    
        nbrIR = new Double(NombreInscritRegles());
    
        nbrINR = nbrI - nbrIR;
    
        taux = (nbrINR / nbrI)*100;
    
        String s = format(taux,2,1);
    
        return s;
    }
    
    
    //---------------------------------------------------------------------------
    // Fonction de calcul du Taux de paiement de la cantine non réglé à l'année.
    //---------------------------------------------------------------------------
    
    private int NombreInscritNonReglesAnnee(int annee) throws SQLException
    {
        int nbrInscritNR = 0;
        String sql = "SELECT SUM(nb_non_paiement) FROM non_paiement" +
                " WHERE YEAR(Date)=" + annee + ";";
        Statement stmt = con.createStatement();
        ResultSet r = stmt.executeQuery(sql);
        while(r.next())
        {
            nbrInscritNR = Integer.parseInt(r.getString(1));
        }
        return nbrInscritNR;
    }
    
    private int NombreInscritAnnee(int annee) throws SQLException
    {
        int nbrInscritAnnee = 0;
        String sql = "SELECT SUM(nb_personne_inscrite) FROM non_paiement" +
                " WHERE YEAR(Date)=" + annee + ";";
        Statement stmt = con.createStatement();
        ResultSet r = stmt.executeQuery(sql);
        while(r.next())
        {
            nbrInscritAnnee = Integer.parseInt(r.getString(1));
        }
        return nbrInscritAnnee;
    }
    
    public String tauxPaiementsCantineNonRegles(int annee) throws SQLException
    {
        double taux = 0;
        double nbrI = 0;
        double nbrINR = 0;
    
        nbrI = new Double(NombreInscritAnnee(annee));
    
        nbrINR = new Double(NombreInscritNonReglesAnnee(annee));
    
        taux = (nbrINR / nbrI)*100;
    
        String s = format(taux,2,1);
    
        return s;
    }
    
    }

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Réponses: 2
    Dernier message: 04/04/2009, 09h17
  2. Réponses: 5
    Dernier message: 15/04/2008, 15h52
  3. web services, soap et compression.
    Par renaudjuif dans le forum Langage
    Réponses: 6
    Dernier message: 31/07/2006, 15h44
  4. [Web Service] [SOAP] Envoie requete
    Par _beber85 dans le forum JDBC
    Réponses: 1
    Dernier message: 08/06/2006, 09h31
  5. Comment consommer un web service en java
    Par Vins83 dans le forum Services Web
    Réponses: 1
    Dernier message: 16/01/2006, 23h33

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