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

JDBC Java Discussion :

Hibernate insert base de données


Sujet :

JDBC Java

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 225
    Points : 132
    Points
    132
    Par défaut Hibernate insert base de données
    Bonjour,

    Pour améliorer la performance de mes insert avec hibernate, j'ai vu qu'on pouvais utiliser un système de batch_size:
    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
    	<bean id="sqlServerDataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
    		<property name="jndiName" value="java:comp/env/jdbc/db" />
    	</bean>
     
    	<bean id="sqlServerEntityManagerFactory"
    		class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    		<property name="dataSource" ref="sqlServerDataSource" />
    		<property name="packagesToScan" value="package" />
    		<property name="jpaVendorAdapter">
    			<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
    		</property>
    		<property name="jpaProperties">
    			<props>
           			<prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
    				<prop key="hibernate.show_sql">true</prop>
    				<prop key="hibernate.enable_lazy_load_no_trans">true</prop>
    				<prop key="hibernate.jdbc.batch_size">1000</prop>
                	<prop key="hibernate.order_inserts">true</prop>
                	<prop key="hibernate.order_updates">true</prop>
                	<prop key="hibernate.jdbc.batch_versioned_data">true</prop>
    			</props>
    		</property>
    	</bean>
     
     
    	<bean id="sqlServerTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    		<property name="entityManagerFactory" ref="sqlServerEntityManagerFactory" />
    	</bean>
    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
     
    	/** sqlServerEntityManagerFactory */
    	@PersistenceContext(unitName="sqlServerEntityManagerFactory")  
    	private EntityManager sqlServerEntityManagerFactory;
     
    	@Transactional(value="sqlServerTransactionManager")
    	public void save(List<Object> listObjet){
    		int batchSize = 1000;
     
    		for (int i = 0; i < listObjet.size(); i++){
    			Object object= listObjet.get(i);
    			sqlServerEntityManagerFactory.persist(object);
     
                if (i % batchSize == 0 && i > 0) {
                	sqlServerEntityManagerFactory.flush();
                	sqlServerEntityManagerFactory.clear();
                }
            }
     
    	}
    Le problème c'est que rien ne s'ajoute dans ma base de données

  2. #2
    Membre expérimenté Avatar de Cincinnatus
    Homme Profil pro
    Développeur d'applications métier
    Inscrit en
    Mars 2007
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur d'applications métier
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2007
    Messages : 592
    Points : 1 679
    Points
    1 679
    Par défaut
    Citation Envoyé par totot Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
                if (i % batchSize == 0 && i > 0) {
                    sqlServerEntityManagerFactory.flush();
                    sqlServerEntityManagerFactory.clear();
                }
    Le problème c'est que rien ne s'ajoute dans ma base de données
    Bonjour,

    Est-ce que la condition ci-dessus est remplie ? Un log peut permettre de vérifier que ces opérations sont bien effectuées.
    Et un commit est-il réellement effectué par le flush ? (je n'utilise pas SqlServer, et comme les bases ont chacune leurs façons de se comporter par défaut...)

Discussions similaires

  1. Comment synchroniser Hibernate avec base de données
    Par ZeroOne dans le forum Hibernate
    Réponses: 1
    Dernier message: 26/01/2009, 19h34
  2. Insertion base de données
    Par nattyroot dans le forum Accès aux données
    Réponses: 1
    Dernier message: 01/10/2008, 19h52
  3. Problème d'insertion base de donnée Access
    Par hh4life dans le forum Windows Forms
    Réponses: 2
    Dernier message: 28/08/2007, 19h26
  4. [DBExpress] Formulaire d'insertion (Base de donnée)
    Par Nadd dans le forum C++Builder
    Réponses: 14
    Dernier message: 12/07/2007, 10h22
  5. insertion base de donnée
    Par eriz dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 20/04/2007, 00h47

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