NHibernate.StaleStateException : Inattendue du nombre de lignes: 0; attendu: 1

Hl Les Gars,

Je suis en train de rédiger un backend d'administration du programme pour un système qui existe. J'ai sélectionné NHibernate pour ma solution d'accès aux données et je suis assez nouveau pour elle. Je rencontre l'erreur suivante dans une relation parent/enfant:

NHibernate.StaleStateException : Inattendue du nombre de lignes: 0; attendu: 1

Cette erreur est causée par le fait que dans mon code source, j'ai ajouter le nouvel objet enfant dans le parent de la collection d'enfants de MeetingAdministrators. Lorsque j'enregistre l'objet parent-je attendre que les enfants soient ajoutés, cependant une INSERTION est généré uniquement pour l'objet parent. Nhibernate ne génère pas de l'INSERTION, pour l'enfant, mais essaie plutôt de mettre à JOUR l'enfant, même si elle n'existe pas. Ainsi, il affiche le message d'erreur indiqué ci-dessus. J'ai cherché partout sur le web et nhibernate de la documentation pour ce scénario, mais n'ont trouvé aucune aide. La plupart du code implique des clés étrangères qui ne font pas partie de la clé primaire, ou les gens semblent être aux prises avec un-à-un ou plusieurs-à-plusieurs liens. J'ai besoin de spécifier le mappage et le code de sorte que lors de l'insertion de la mère, les enfants s'insérés. S'il vous plaît aider.

Ma structure de données est comme suit:

Réunion – table parent

  • MeetingID (pk) (int, identité)
  • Description
  • StartDate
  • Est actif
  • Lieu

MeetingAdministrator – table enfant

  • MeetingID (pk, fk)
  • AdminNetworkID (pk) (varchar)
  • DateCreated
  • Est actif

Et voici le Visuel de Base .NET source:

<Serializable()> _
Public Class MeetingAdministrator
Private _MeetingID As Integer
Public Overridable Property MeetingID() As Integer
Get
Return _MeetingID
End Get
Set(ByVal value As Integer)
_MeetingID = value
End Set
End Property
Private _AdminNetworkID As String
Public Overridable Property AdminNetworkID() As String
Get
Return _AdminNetworkID
End Get
Set(ByVal value As String)
_AdminNetworkID = value
End Set
End Property
Private _IsActive As Byte
Public Overridable Property IsActive() As Byte
Get
Return _IsActive
End Get
Set(ByVal value As Byte)
_IsActive = value
End Set
End Property
Private _DateCreated As Date
Public Overridable Property DateCreated() As Date
Get
Return _DateCreated
End Get
Set(ByVal value As Date)
_DateCreated = value
End Set
End Property
Private _LastModified As Date
Public Overridable Property LastModified() As Date
Get
Return _LastModified
End Get
Set(ByVal value As Date)
_LastModified = value
End Set
End Property
Private _meeting As Meeting
Public Overridable Property Meeting() As Meeting
Get
Return _meeting
End Get
Set(ByVal value As Meeting)
_meeting = value
End Set
End Property
Public Overrides Function Equals(ByVal obj As Object) As Boolean
Return MyBase.Equals(obj)
End Function
Public Overrides Function GetHashCode() As Integer
Return MyBase.GetHashCode()
End Function
End Class
Imports Iesi.Collections
Imports Iesi.Collections.Generic
Public Class Meeting
Private _MeetingID As Integer
Private _Description As String
Public Overridable Property MeetingID() As Integer
Get
Return _MeetingID
End Get
Set(ByVal value As Integer)
_MeetingID = value
End Set
End Property
Public Overridable Property Description() As String
Get
Return _Description
End Get
Set(ByVal value As String)
_Description = value
End Set
End Property
Private _StartDate As Date = Now
Public Overridable Property StartDate() As Date
Get
Return _StartDate
End Get
Set(ByVal value As Date)
_StartDate = value
End Set
End Property
Private _IsActive As Byte
Public Overridable Property IsActive() As Byte
Get
Return _IsActive
End Get
Set(ByVal value As Byte)
_IsActive = value
End Set
End Property
Private _DateCreated As Date
Public Overridable Property DateCreated() As Date
Get
Return _DateCreated
End Get
Set(ByVal value As Date)
_DateCreated = value
End Set
End Property
Private _Venue As String
Public Overridable Property Venue() As String
Get
Return _ Venue
End Get
Set(ByVal value As String)
_ Venue = value
End Set
End Property
Private _meetingAdministrator As ISet(Of MeetingAdministrator)
Public Overridable Property MeetingAdministrators() As ISet(Of MeetingAdministrator)
Get
Return _meetingAdministrator
End Get
Set(ByVal value As ISet(Of MeetingAdministrator))
_meetingAdministrator = value
End Set
End Property
Public Overridable Sub AddAdministrator(ByVal meetingAdministrator As MeetingAdministrator)
meetingAdministrator.Meeting = Me
_meetingAdministrator.Add(meetingAdministrator)
End Sub
Public Sub New()
_meetingAdministrator = New HashedSet(Of MeetingAdministrator)()
End Sub
End Class

Voici les fichiers de mappage:

<!-- Meeting.hbm.xml -->
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Data"
namespace="Data.Domain" >
<!-- Mapping Information -->
<class name="Meeting"  table="Meeting" >
<id name="MeetingID" column="MeetingID" type="int">
<generator class="identity" />
</id>
<property name="Description" />
<property name="StartDate" />
<property name="IsActive" />
<property name="Venue" />
<set name="MeetingAdministrators" table="MeetingAdministrator" inverse="true"  lazy="true"  cascade="save-update"  access="property" >
<key column="MeetingID"  foreign-key="MeetingID"  />
<one-to-many class="Meeting"  />
</set>
</class>
</hibernate-mapping>
<!-- MeetingAdministrator.hbm.xml -->
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="Data"
namespace="Data.Domain" >
<!-- Mapping Information -->
<class name="MeetingAdministrator"  table="MeetingAdministrator" >
<composite-id>
<key-property  name="AdminNetworkID"  column="AdminNetworkID"  type="string"  >
</key-property>
<key-many-to-one name="Meeting" class="Meeting" >
<column name="MeetingID" />
</key-many-to-one>
</composite-id>
<property name="IsActive" />
<property name="DateCreated" />
</class>
</hibernate-mapping>

OriginalL'auteur Tachi | 2010-09-18