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

Spring Java Discussion :

Mauvaise gestion des transactions? [Data]


Sujet :

Spring Java

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 214
    Points : 100
    Points
    100
    Par défaut Mauvaise gestion des transactions?
    Bonjour à tous.

    J'utilise Spring 3.0.4 et Hibernate 3.5.5 et j'ai quelques soucis à faire fonctionner une transaction.
    Il faut savoir que je ne maîtrise pas le concept (enfin si de manière théorique) et que je suis donc quasiment certain que mon problème est ridicule.

    Bref, j'ai voulu effectuer un test pour voir si la transaction que j'ai créé était bien active et il se trouve que malgré la RuntimeException lancée, le premier insert aura bien lieu dans ma DB (MySQL).

    Voici donc ce que j'ai fais.

    Dans mes fichiers de configuration Spring:

    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
    	<!-- HibernateTransactionManager provided by Spring -->
    	<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    		<property name="sessionFactory" ref="sessionFactory"/>
    	</bean>
     
    	<!-- HibernateTemplate provided by Spring -->
    	<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
    		<property name="sessionFactory" ref="sessionFactory"/>
    	</bean>
     
    <tx:annotation-driven transaction-manager="transactionManager"/>
     
    <!-- Mon service -->
    	<bean id="serverService" class="com.lanengine.core.domain.services.ServerServiceImpl">
    		<property name="serverDao" ref="serverDao" />
    		<property name="gameService" ref="gameService" />
    		<property name="fluxService" ref="fluxService" />
    		<property name="validator" ref="validator" />
    	</bean>
     
    <!-- Mon dao -->
    	<bean id="serverDao" class="com.lanengine.core.domain.dao.ServerDaoImpl">
    		<property name="sessionFactory" ref="sessionFactory"/>
    	</bean>
    Dans ServerServiceImpl, voici ce que je fais:

    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
    	@Transactional
    	public String uploadServersFromFile(MultipartFile file) {
    		try {
    			ServersDTO serversDTO = fluxService.loadObjectFromFile(file);
    			if (serversDTO == null || serversDTO.getServerList() == null) {
    				return "cannotRead";
    			}
    			ObjectImportResult<Server, ServerDTO> importResult = getServersListFromDTO(serversDTO.getServerList());
    			if (!importResult.getValueAndErrorListByObjectDTO().isEmpty()) {
    				return "error";
    			} else {
    				serverDao.save(importResult.getObjects());
    				return "1";
    			}
    		} catch (UnknownFileTypeException e) {
    			return "wrongFileType";
    		}
    	}
    (C'est du test hein )
    Notez l'appel de serverDao.save(); que je vous détaille ci-dessous:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    	public void save(List<Server> servers) {
    		for (Server server : servers) {
    			getHibernateTemplate().save(server);
    			throw new HibernateException("oups");
    		}
    	}
    Seulement voilà, après exécution du code, le premier serveur sera bien inséré dans la DB...

    Alors quid?

    Merci d'avance pour votre aide.

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 214
    Points : 100
    Points
    100
    Par défaut
    Toujours pas d'idée?

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 16
    Points : 20
    Points
    20
    Par défaut
    Bonjour,

    Quel moteur de stockage utilisez vous sur MySql? MyIsam ou InnoDB? Par défaut, votre base utilisera MyIsam qui ne sait pas gérer les transactions et donc toutes les commandes seront automatiquement comitées même malgré le auto comit à false (pour gérer la transaction).

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 214
    Points : 100
    Points
    100
    Par défaut
    Citation Envoyé par vhalalla Voir le message
    Bonjour,

    Quel moteur de stockage utilisez vous sur MySql? MyIsam ou InnoDB? Par défaut, votre base utilisera MyIsam qui ne sait pas gérer les transactions et donc toutes les commandes seront automatiquement comitées même malgré le auto comit à false (pour gérer la transaction).
    J'avais oublié ce post.
    Et en effet vous avez donné la bonne solution

    Bonne journée!

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

Discussions similaires

  1. Gestion des transactions avec les composants DOA
    Par lper dans le forum Bases de données
    Réponses: 2
    Dernier message: 01/12/2008, 17h06
  2. [Data] Gestion des transactions
    Par hlr dans le forum Spring
    Réponses: 2
    Dernier message: 21/02/2006, 10h47
  3. firefox - mauvaise gestion des passwords
    Par photorelief dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 10/06/2005, 10h02
  4. Gestion des transactions - Gestion des erreurs
    Par devdev dans le forum MS SQL Server
    Réponses: 14
    Dernier message: 23/03/2005, 21h17
  5. gestion des transactions
    Par viny dans le forum Requêtes
    Réponses: 2
    Dernier message: 26/03/2004, 22h53

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