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

Servlets/JSP Java Discussion :

filtrer un résultat a partir de date de début et date de fin


Sujet :

Servlets/JSP Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Avril 2018
    Messages : 20
    Par défaut filtrer un résultat a partir de date de début et date de fin
    Bonjour,
    j'essaie de faire filtre une résultat sous forme d'une liste en entrant la date de début et la date de fin.
    voici la table de base de données:
    Nom : base.png
Affichages : 742
Taille : 15,2 Ko
    voici listeentree.jsp:
    Nom : 11111.png
Affichages : 848
Taille : 15,7 Ko
    j'ai fait une méthode pour récupérer le résultat:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public List<Entree> RechercherParDate(Date datedebut,Date datefin) {
    		return (ArrayList<Entree>)em.createQuery("SELECT a FROM Entree a WHERE dateEntree BETWEEN '"+datedebut+"' AND '"+datefin+"'").getResultList();
    		}
    voici le code de listeentree.jsp:
    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
     
    <%@page import="java.util.ArrayList"%>
    <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
    <%@page import="entity.Entree"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
    <title>LISTE DES ENTREES EN STOCK</title>
    </head>
    <body>
    <div>
    		<h2>
    			<b style="color: blue;"> Liste des entrées en stock</b>
    		</h2>
    		<hr width="100%;">
    	</div>
     
    <form>	<table>
    <tr><td>Date entrée début : <input type="date" name="datedebut" required ><td> &nbsp <input type="button" value="Nouvelle Entrée" onclick="document.location.href='NouvelleEntreeCtl';"></br></tr>
    </tr><td>Date entrée fin: <input type="date" name="datefin" required></td> &nbsp<td><input type="submit"  value="Filtrer" action="ListeEntreesCtl" method="post" ></td></tr>
     
    <table border="1px" width="80%">
     
        	    <tr>
    					<td><b>Date Entrée</b></td>
    					<td><b>Reférence</b></td>
    					<td><b>Montant total</b></td>
    					<td><b>Action</b></td>
    				</tr>
     
    <%
     
    ArrayList<Entree> entree1 =(ArrayList<Entree>) request.getAttribute("entrees");
    if (entree1!=null){
    for(Entree a : entree1) {
    %>
    				<tr>
    					<td><%= a.getDateEntree() %></td>
    					<td><%= a.getRefEntree() %></td>
    					<td><%= a.getPrixTotalEntree() %></td>
    				<td><a
    						href="<%=application.getContextPath()%>/Details?id=<%=a.getCodeEntree()%>">
    							Détails </a>
    				</tr>
    								<%
    }
    }
    %>	
     
     
     
    </table>
     
    </table>
    </form>
     
    </body>
    </html>
    voici le code de listeentreeCtl.java (le servelet):
    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
     
    package controleur;
     
    import java.io.IOException;
    import java.text.DateFormat;
    import java.text.SimpleDateFormat;
    import java.util.Date;
    import java.util.List;
     
    import javax.ejb.EJB;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
     
     
    import entity.Entree;
    import session.ArticleEJBImplLocal;
     
    @WebServlet(name="en",urlPatterns="/ListeEntreesCtl")
    public class ListeEntreesCtl extends HttpServlet {
    	private static final long serialVersionUID = 1L;
     
    	private static final String Date = null;
     
    	@EJB
    	private ArticleEJBImplLocal imp; 
     
     
     
    	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
     
    		request.getRequestDispatcher("ListeEntrees.jsp").forward(request, response);	
    	}
     
     
    	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    		Date datedebut = null;
    		Date datefin = null;
    		SimpleDateFormat formatter = new SimpleDateFormat("yyyy-mm-dd");
    		if ((request.getParameter("datedebut") != null) && (!request.getParameter("datedebut").toString().isEmpty())) {
     
     
    			try {
     
    				datedebut = formatter.parse(request.getParameter("datedebut"));
    			} catch (java.text.ParseException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}
    if ((request.getParameter("datefin") != null) && (!request.getParameter("datefin").toString().isEmpty())) {
     
     
    			try {
     
    				datefin = formatter.parse(request.getParameter("datefin"));
    			} catch (java.text.ParseException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}
    List<Entree> entree1 = imp.RechercherParDate(datedebut, datefin);
    request.setAttribute("entrees", entree1);
     
    }}
    		doGet(request, response);
    	}
     
    }
    après l’exécution je n'obtient rien comme résultat

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    return (ArrayList<Entree>)em.createQuery("SELECT a FROM Entree a WHERE dateEntree BETWEEN '"+datedebut+"' AND '"+datefin+"'").getResultList();
    Si dateEntree est de type date dans la base:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    return (ArrayList<Entree>)em.createQuery("SELECT a FROM Entree a WHERE a.dateEntree BETWEEN :debut AND :fin).setParameter("debut", datedebut, TemporalType.DATE)
          .setParameter("fin", datefin, TemporalType.DATE).getResultList();
    Sinon, as-tu d'erreur dans le log?

    A+.

  3. #3
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Avril 2018
    Messages : 20
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Bonjour,


    Si dateEntree est de type date dans la base:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    return (ArrayList<Entree>)em.createQuery("SELECT a FROM Entree a WHERE a.dateEntree BETWEEN :debut AND :fin).setParameter("debut", datedebut, TemporalType.DATE)
          .setParameter("fin", datefin, TemporalType.DATE).getResultList();
    Sinon, as-tu d'erreur dans le log?

    A+.
    j'ai essayer avec votre solution mais rien na été changer.

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par jean2020 Voir le message
    j'ai essayer avec votre solution mais rien na été changer.
    Le problème est le même qu'ici : tu fais un get alors que tu ne traites les paramètres que dans la méthode doPost...
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  5. #5
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Avril 2018
    Messages : 20
    Par défaut
    Citation Envoyé par joel.drigo Voir le message
    Le problème est le même qu'ici : tu fais un get alors que tu ne traites les paramètres que dans la méthode doPost...
    j'ai changer le traitement dans doGet mais le même problème j'ai rien comme résultat:
    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
     
    package controleur;
     
    import java.io.IOException;
    import java.text.DateFormat;
    import java.text.SimpleDateFormat;
    import java.util.Date;
    import java.util.List;
     
    import javax.ejb.EJB;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
     
     
    import entity.Entree;
    import session.ArticleEJBImplLocal;
     
    @WebServlet(name="en",urlPatterns="/ListeEntreesCtl")
    public class ListeEntreesCtl extends HttpServlet {
    	private static final long serialVersionUID = 1L;
     
    	private static final String Date = null;
     
    	@EJB
    	private ArticleEJBImplLocal imp; 
     
     
     
    	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    		Date datedebut = null;
    		Date datefin = null;
    		SimpleDateFormat formatter = new SimpleDateFormat("yyyy-mm-dd");
    		if ((request.getParameter("datedebut") != null) && (!request.getParameter("datedebut").toString().isEmpty())) {
     
     
    			try {
     
    				datedebut = formatter.parse(request.getParameter("datedebut"));
    			} catch (java.text.ParseException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}
    if ((request.getParameter("datefin") != null) && (!request.getParameter("datefin").toString().isEmpty())) {
     
     
    			try {
     
    				datefin = formatter.parse(request.getParameter("datefin"));
    			} catch (java.text.ParseException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}
    List<Entree> entree1 = imp.RechercherParDate(datedebut, datefin);
    request.setAttribute("entrees", entree1);
     
    }}
    		request.getRequestDispatcher("ListeEntrees.jsp").forward(request, response);	
    	}
     
     
    	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
     
    		doGet(request, response);
    	}
     
    }

  6. #6
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Il y a aussi un problème avec ton format de date : mm c'est pour les minutes, pour les mois c'est MM.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 05/05/2017, 10h30
  2. Réponses: 0
    Dernier message: 11/05/2011, 00h11
  3. Paramètrer une date de début et date fin
    Par diop18 dans le forum iReport
    Réponses: 3
    Dernier message: 14/05/2009, 17h14
  4. [A-07] Dates de début et dates fin en fonction du N° de semaine
    Par ifrpi dans le forum Requêtes et SQL.
    Réponses: 11
    Dernier message: 20/10/2008, 09h37
  5. Réponses: 2
    Dernier message: 21/03/2007, 16h06

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