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

NHibernate Discussion :

NHibernate et les clés primaires


Sujet :

NHibernate

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 33
    Points : 23
    Points
    23
    Par défaut NHibernate et les clés primaires
    Bonjour,

    J'insére des données via NHibernate, avec une clé primaire, générée automatiquement lors des insertions. Le fait est que j'ai besoin de cette clé juste après une insertion pour une autre insertion dans une autre table.

    Est-ce qu'il existe une méthode qui retourne l'objet inséré ou juste la clé primaire??

    Une autre requête, comment stopper en ASP, l'exécution d'une requête.
    En effet, actuellement, si l'utilisateur appuie sur 'arrêter', les insertions continuent !!

  2. #2
    Membre habitué
    Inscrit en
    Juin 2005
    Messages
    110
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Juin 2005
    Messages : 110
    Points : 128
    Points
    128
    Par défaut
    Hello,

    A mon avis, tu n'es pas forcement dans la bonne logique.
    Avec hibernate il ne faut pas que tu penses en termes de tables mais plutôt d'objets. Si une table fait référence à une autre, c'est plutôt qu'un objet est lié à un autre. Donc le plus simple est plutôt de créer une collection d'objet fils du premier (une relation n-aire on pourrait dire). Par exemple tu renseignes une "personne" et des "adresse"s : Ne pas dire que tu insères en base la personne, puis tu récupères l'id de la personne et tu insères des adresses. Mais plûtot tu as un objet personne qui à une propriété "adresses" qui est un ICollection d'"adresse". L'objet "adresse" est mappé sur la table adresse et l'objet personne à une relation "one-to-many" avec l'objet "adresse".
    Tu as un classe adresse et dans ta classe Personne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
           #region Elements mappés
     
            private ICollection adresses;
            public virtual ICollection Adresses
            {
                get { return adresses; }
                set { adresse = value; }
            }
     
            #end region
    Du coup quand tu as créé ton objet personne, il suffit que tu renseignes la propriété "adresses" pour pouvoir remplir les tables.

    Je ne sais pas trop si j'ai été clair...

    L.

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 33
    Points : 23
    Points
    23
    Par défaut
    bonjour et merci

    si si c'est bien clair et c'est ce que j'ai fait :
    j'ai ajouté un attribut 'adresse' à ma classe 'personne' mais dans le mappage hbm.xml, j'ai besoin de définir le lien entre les deux objets, non?

    je veux dire que je mappe les deux objets et dans la partie de l'objet personne je dis que j'ai un one-to-one
    C'est ce que j'ai fait en tout cas mais ca ne marche pas.

    Dans celui de adresse mais pas Personne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     
    <class name="Test.Adresse, Test" table="ADRESSE">
    		<id name="IdPersonne" column="ID_PERSONNE" type="int" length="4">
    			<generator class="assigned" />
    		</id>
    		<property name="Details" column="DETAILS" type="string" length="4" />	
    		<one-to-one name="Adresse" class="Test.Personne, Test" constrained="true"/>			
    	</class>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <class name="Test.Personne, Test" table="PERSON">
    		<id name="IdPersonne" column="ID_PERSONNE" type="int" length="4">
    			<generator class="assigned" />
    		</id>
    		<property name="Nom" column="NOM" type="string" length="4" />	
    		<one-to-one name="Adresse" class="Test.Adresse, Test" constrained="true"/>			
    	</class>
    Le problème aussi est que dans ma table adresse j'ai une clé primaire composé de plusieurs colonnes (par exemple ID_PERSONNE et DETAILS)

    aussi moi je veux recupere l'idPersonne de PERSOn dans IdPersonne de ADRESSE

Discussions similaires

  1. savoir les clés primaires d'une table
    Par hamdani dans le forum Administration
    Réponses: 6
    Dernier message: 21/05/2007, 16h54
  2. Les trous dans les clés primaires d'une base de données ?
    Par dymezac dans le forum Décisions SGBD
    Réponses: 7
    Dernier message: 27/09/2006, 09h22
  3. Récupérer les clés primaires "perdues"
    Par Dnx dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 12/07/2006, 17h13
  4. [EJB2.1 Entity] [CMP] [xdoclet] Problème avec les clés primaires
    Par shingo dans le forum Java EE
    Réponses: 1
    Dernier message: 10/02/2006, 16h41
  5. [C#] Probleme sur les clés primaires composites
    Par stardeus dans le forum Windows Forms
    Réponses: 7
    Dernier message: 12/02/2005, 23h28

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