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 :

supprimer plusieurs lignes d'une table


Sujet :

Servlets/JSP Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 59
    Par défaut supprimer plusieurs lignes d'une table
    Bonjour ,
    je travaille sur une application J2ee avec ejb et jsf ainsi qu'une BD postgre, il s'agit en fait , d'une application de gestion de departements et je souhaite supprimer plusieurs lignes d'une table via une page jsf, mon problème c'est que j'arrive à supprimer une seule ligne , pour plusieurs je ne sais pas comment proceder.
    Si vous avez des suggestions n'hesitez pas à m'en faire part.
    Merci d'avance
    Code de suppression d'une seule ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    public void remove(Departement d) {
    		// TODO Auto-generated method stub
    	EntityManager em=emf.createEntityManager();
    	Departement dept=em.find(Departement.class,d.getNumero());
    		em.getTransaction().begin();
    		em.remove(dept);
    		em.getTransaction().commit();
    	}

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    52
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 52
    Par défaut
    Salut a toi hajarussa...

    Pourrais-tu nous donner ta classe Departement, on aura plus de facilité à te répondre correctement.

    Néamoins je te donne une piste:

    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
     
    // Suppression d'un departement
    public void remove(Departement d) {
            // TODO Auto-generated method stub
        EntityManager em=emf.createEntityManager();
        Departement dept=em.find(Departement.class,d.getNumero());
            em.getTransaction().begin();
            em.remove(dept);
            em.getTransaction().commit();
        }
     
    // suppression d'une liste de departement
    public void remove(List<Departement> lesDepts) {
        for (Iterator<Departement> it = lesDepts.iterator(); it.hasNext();) {
            remove(it.next());
        }
    }
    en gros, tu surcharge ta fonction remove en y mettant un paramètre de type List afin de pouvoir faire remove(lesDeptsASupprimer).
    le remove(List) se chargera de parcourir ta liste afin de supprimer les départements un a un en utilisant la fonction que tu as écris auparavant.


    Tiens nous au courant et n'oublie pas le tag Résolu si c'est le cas.

    Bien à toi.
    Cordialement.
    Scarz.

  3. #3
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 59
    Par défaut
    Salut Scarz,
    Merci pour ta reponse , je te donne le code de la classe departement.
    Merci.
    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
     
    package tp;
     
    import java.util.List;
     
    import javax.ejb.Local;
    import javax.ejb.Stateless;
    import javax.ejb.TransactionManagement;
    import javax.ejb.TransactionManagementType;
    import javax.persistence.EntityManager;
    import javax.persistence.EntityManagerFactory;
    import javax.persistence.PersistenceUnit;
     
    import org.jboss.annotation.ejb.LocalBinding;
     
    /**
     * Session Bean implementation class DepartementDAOBean
     */
    @Stateless
    @Local({DepartementDAOLocal.class})
    @LocalBinding(jndiBinding="departementDAO/local")
    @TransactionManagement(TransactionManagementType.BEAN)
    public class DepartementDAOBean implements DepartementDAOLocal {
     
        /**
         * Default constructor. 
         */
    	@PersistenceUnit(name="Projet8EJB3")
    	private EntityManagerFactory emf;
        public DepartementDAOBean() {
            // TODO Auto-generated constructor stub
        }
     
    	public void create(Departement d) {
    		// TODO Auto-generated method stub
    		EntityManager em=emf.createEntityManager();
    		em.getTransaction().begin();
    		em.persist(d);
    		em.getTransaction().commit();
    	}
     
    	public List<Departement> display() {
    		// TODO Auto-generated method stub
    		EntityManager em=emf.createEntityManager();
    		return em.createQuery("from Departement").getResultList();
    	}
     
    	public void remove(Departement d) {
    		// TODO Auto-generated method stub
    		EntityManager em=emf.createEntityManager();
    		Departement dept=em.find(Departement.class, d.getNumero());
    		em.getTransaction().begin();
    		em.remove(dept);
    		em.getTransaction().commit();
    	}
     
    }

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    52
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 52
    Par défaut
    C'est un plaisir de pouvoir t'aider.

    Donc si tu reprends mon post précédent, il te suffit de rajouter la méthode remove(List<Departement> lesDepts) à ta classe DepartementDAOBean et tu pourras ainsi supprimer une liste de département.

    N'oublie pas de nous faire part des suites de ton périple (résolu ou pas).

    Bien à toi.
    Scarz.

Discussions similaires

  1. [SQL] Supprimer les lignes d'une table sql
    Par radhwene dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 28/06/2007, 11h48
  2. [VBA] Supprimer des lignes dans une table
    Par shadockgreg dans le forum Access
    Réponses: 6
    Dernier message: 22/11/2006, 09h58
  3. MAJ de plusieurs lignes d'une table
    Par bencheikh dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 05/08/2006, 10h47
  4. Mettre a jour plusieurs lignes d'une table
    Par Tartenpion dans le forum Langage SQL
    Réponses: 4
    Dernier message: 17/12/2005, 18h50
  5. Procédure stockée - Retourner plusieurs ligne d'une table
    Par ronando dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 02/11/2005, 13h19

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