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

Hibernate Java Discussion :

[HIBERNATE] Delete d'un objet


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite

    Profil pro
    Inscrit en
    Juin 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2004
    Messages : 882
    Par défaut [HIBERNATE] Delete d'un objet
    Bonsoir je me pose une question par rapport à une suppression d'un objet identifié par son id... Je travaille avec Hibernate 3

    Voici le code que j'utilise pour cela
    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
     
        public void deleteMember(Long memberID) {
            // DAO to delete
            MemberDAO memberDAO = null;
     
            try {
                Session session = HibernateHelper.currentSession();
     
                // Loading object
                memberDAO = (MemberDAO) session.get(MemberDAO.class, memberID);
     
                // Deleting object
                session.delete(memberDAO);
     
            } catch (HibernateException e) {
            } finally {
                HibernateHelper.closeSession();
            }
        }
    Je dois loader l'objet persistant avant de pouvoir le supprimer, jusqu'ici tout est normal mais n'y a t il pas un moyen plus simple pour supprimer un objet identifié par son id???

    Merci

  2. #2
    Membre chevronné
    Inscrit en
    Août 2005
    Messages
    352
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 352
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    session.delete("from player in class example.Player where player.annualSalary > 4000000");
     
     
    String hqlDelete = "delete Customer where name = :oldName";
    int deletedEntities = s.createQuery( hqlDelete )
                                   .setString( "oldName", oldName )
                                   .executeUpdate();

  3. #3
    Membre émérite

    Profil pro
    Inscrit en
    Juin 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2004
    Messages : 882
    Par défaut
    Citation Envoyé par dlemoing
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    session.delete("from player in class example.Player where player.annualSalary > 4000000");
     
     
    String hqlDelete = "delete Customer where name = :oldName";
    int deletedEntities = s.createQuery( hqlDelete )
                                   .setString( "oldName", oldName )
                                   .executeUpdate();
    Ok effectivement, ici nous n'avons pas besoin de charger un objet persistant (select) pour le supprimer (delete) et c'est donc plus léger

    Merci a toi

  4. #4
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    70
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 70
    Par défaut Suppression d'une occurence
    j'ai fais ce code afin de supprimer une occurence de la Table Bcn :
    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
     
    public class SuppressionBcnBean 
     
    {    
    	 private String Titre;
         private String serie;
         private int ndeb;
         private int nfin;
         private int qte;
         private int numbcn;
         private Date dtbcn;
         private int cdart;
         private String cddep;
         private String logincre;
         private Date datecre;
         private String loginmod;
         private Date datemod;
         private String msg;
         public SuppressionBcnBean(){}
     
         public String getMsg() {
    		return msg;
    	}
     
    	public void setMsg(String msg) {
    		this.msg = msg;
    	}
     
    	public String getLogincre() {
    		return logincre;
    	}
     
    	public void setLogincre(String logincre) {
    		this.logincre = logincre;
    	}
     
    	public Date getDatecre() {
    		return datecre;
    	}
     
    	public void setDatecre(Date datecre) {
    		this.datecre = datecre;
    	}
     
    	public String getLoginmod() {
    		return loginmod;
    	}
     
    	public void setLoginmod(String loginmod) {
    		this.loginmod = loginmod;
    	}
     
    	public Date getDatemod() {
    		return datemod;
    	}
     
    	public void setDatemod(Date datemod) {
    		this.datemod = datemod;
    	}
     
    	public int getCdart() {
    		return cdart;
    	}
    	public void setCdart(int cdart) {
    		this.cdart = cdart;
    	}
    	public String getCddep() {
    		return cddep;
    	}
    	public void setCddep(String cddep) {
    		this.cddep = cddep;
    	}
     
     
     
    	public String getTitre() {
    		return Titre;
    	}
    	public void setTitre(String titre) {
    		Titre = titre;
    	}
    	public String getSerie() {
    		return serie;
    	}
    	public void setSerie(String serie) {
    		this.serie = serie;
    	}
    	public int getNdeb() {
    		return ndeb;
    	}
    	public void setNdeb(int ndeb) {
    		this.ndeb = ndeb;
    	}
    	public int getNfin() {
    		return nfin;
    	}
    	public void setNfin(int nfin) {
    		this.nfin = nfin;
    	}
    	public int getQte() {
    		return qte;
    	}
    	public void setQte(int qte) {
    		this.qte = qte;
    	}
    	public int getNumbcn() {
    		return numbcn;
    	}
    	public void setNumbcn(int numbcn) {
    		this.numbcn = numbcn;
    	}
    	public Date getDtbcn() {
    		return dtbcn;
    	}
    	public void setDtbcn(Date dtbcn) {
    		this.dtbcn = dtbcn;
    	}
     
    	public String supprimer()
    	{
    		boolean verif = false;
     
    		SessionFactory sessionfactory = new Configuration().configure().buildSessionFactory();
    		Session session = sessionfactory.openSession();
    		try
    		{   
     
    			String hqlDelete = "delete Bcn where idTitre=:tt";
    	        session.createQuery( hqlDelete ).setString( "tt",this.Titre );
    	        verif = true;
    		}
    		finally
    		{
    			session.close();
    		}
    		sessionfactory.close();
     
    		if ( verif = true)
    		{
    			this.msg="Suppression effectue";
    			return "ok";
    		}
    		else
    		{
    			this.msg = "Suppression non effectué";
    			return "nok";
    		}
     
     
    	}
     
    }
    *

    Lors de l'execution y avait pas une exception et dans ma page jsp s'affiche le message "suppresion effectue " or lorque j'ai consulté la base la ligne existe encore
    quel rectification dois je faire svp ? et merci

  5. #5
    Invité de passage
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1
    Par défaut
    Dans ton code, à aucun moment tu n'exécutes ta requête. En effet tu as écris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    String hqlDelete = "delete Bcn where idTitre=:tt";
    	        session.createQuery( hqlDelete ).setString( "tt",this.Titre );
    	        verif = true;
    alors qu'il te manque la ligne de code suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Query query = session.createQuery( hqlDelete ).setString( "tt",this.Titre );
    query.executeUpdate();

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

Discussions similaires

  1. Probleme Hibernate suppression d'un objet
    Par mrjeronimo dans le forum Hibernate
    Réponses: 6
    Dernier message: 25/03/2008, 10h22
  2. hibernate delete lists + update
    Par bendf82 dans le forum Hibernate
    Réponses: 1
    Dernier message: 04/10/2007, 09h20
  3. [Hibernate] - Delete Childs On Update ?
    Par yakamax dans le forum Hibernate
    Réponses: 6
    Dernier message: 16/02/2007, 14h03
  4. [Hibernate] Chargement d'un objet avec XX sous niveau ?
    Par Hikage dans le forum Hibernate
    Réponses: 2
    Dernier message: 27/07/2006, 17h14
  5. [Hibernate] delete sur un many-to-many
    Par Gob4 dans le forum Hibernate
    Réponses: 1
    Dernier message: 10/05/2006, 16h26

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