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 :

Table sans primary key avec Hibernate


Sujet :

Hibernate Java

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    197
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 197
    Par défaut Table sans primary key avec Hibernate
    Bonjour, voici mon souci.
    Je veux avoir acces aux données d'une TABLE A qui n'a pas de clé primaire (car elle a été faite il y a longtemps).
    Pour obtenir une clé unique de la TABLE A, je concatene 9 champs de la table (ce qui me donne un String).
    Et dans mon code j'ai une variable:
    List<String> listKey
    qui contient l'ensemble des cles unique, et que je souhaite récupérer une liste: List<MonObject> listMonObject
    correspondant au cle unique de la variable listKey.
    Or la TABLE A contient + de 500 000 lignes et ca prend 2 jours au moins

    Voici ma methode dans mon dao:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    @SuppressWarnings("unchecked")
    	public List<MonObject> listByConcatIdProperty(final List<String> propertyList) {
    		final String request = String.format(" from %s"
    				+ " as monObject where (monObject .id.property1 ||'.'|| monObject .id.property2 ||'.'|| "
    				+ "monObject .id.property3 ||'.'|| monObject .id.property4 ||'.'|| monObject .id.property5 ||'.'|| "
    				+ "monObject .id.property6 ||'.'|| monObject .id.property7 ||'.'|| monObject .id.property8 ||'.'|| "
    				+ "monObject .id.cdevcot ||'.'|| monObject .id.property9) in (:propertyList)", getReferenceClass()
    				.getName());
    		final Query query = this.getCacheableQuery(request);
    		query.setParameterList("propertyList", propertyList);
    		return query.list();
    	}
    Auriez-vous une idee d'une autre maniere de procéder qui serai beaucoup + rapide?

    Merci d'avance.

  2. #2
    Membre éprouvé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2003
    Messages
    1 309
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 309
    Par défaut
    Modifier la base en créant une clé primaire composée de ces champs et créer un index sur cette clé. Ca devrait améliorer les performances.

Discussions similaires

  1. Problème foreign key avec hibernate
    Par souhait dans le forum Hibernate
    Réponses: 5
    Dernier message: 05/09/2008, 15h23
  2. Supprimer de la table un primary key de la colonne
    Par hablo_ved dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 02/05/2008, 13h50
  3. ADO- Impossible de mettre à jour une table sans primary key.
    Par Mr_Welby dans le forum Accès aux données
    Réponses: 3
    Dernier message: 26/05/2007, 14h26
  4. auto-incrémentation sur une primary key avec sql server
    Par pops4 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 24/05/2007, 14h24

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