Intento crear una asignación de tabla por jerarquía utilizando NHibernate 2.0.1. Tengo una clase base con propiedades que existen para cada subclase de la que heredan otras clases. Todos estos objetos se conservan en una tabla llamada Mensajes que contienen todos los campos posibles para cada clase. Hay un SourceID que discrimina y debe indicar qué Poco devolver para cada subclase. Aquí está mi mapeo actual.Correlación correcta de una relación polimórfica con NHibernate
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="NS.Core"
namespace="NS.Core.Model">
<class name="BaseMessage" table="Messages">
<id name="MessageID" type="Int64">
<column name="MessageID" />
<generator class="native" />
</id>
<discriminator column="SourceID" type="Int32"/>
<property name="DateCreated" access="property" column="DateCreated" type="DateTime" not-null="true"/>
<property name="DatePublished" access="property" column="DatePublished" type="DateTime"/>
<property name="SourceID" access="property" column="SourceID" type="Int32"/>
<many-to-one name="User" column="UserID" access="property" cascade="none" lazy="false" fetch="join" outer-join="true" />
<subclass name="NMessage" discriminator-value="0">
<property name="Body" access="property" column="Body" type="String"/>
</subclass>
<subclass name="BMessage" discriminator-value="1">
<property name="Title" access="property" column="Title" type="String"/>
<property name="Body" access="property" column="Body" type="String"/>
</subclass>
<subclass name="CMessage" discriminator-value="2">
<property name="Url" access="property" column="Url" type="String"/>
<property name="Body" access="property" column="Body" type="String"/>
</subclass>
</class>
</hibernate-mapping>
me sale un error diciendo consulta No se puede dar formato a un valor de discriminador cadena SQL de la entidad NS.Core.Model.BaseMessage por lo que poner un valor discriminador de esta clase también althout nunca debe devolver la clase base. Eso me llevó a algunos errores antlr.
¿Estoy tomando el enfoque equivocado para este problema? Me gustaría consultar la tabla y obtener una lista de POCO diferentes que todos heredan de la clase base. Nunca devolvería la clase base en sí misma.
a continuación es la BaseMessage.cs
using System;
using System.Collections.Generic;
using System.Runtime.Serialization;
using System.Text;
namespace NS.Core.Model
{
[Serializable]
[DataContract]
[KnownType(typeof(User))]
public class BaseMessage
{
#region Private variables
private long _messageID;
private DateTime? _dateCreated;
private DateTime? _datePublished;
private int _sourceID;
private User _user = new User();
#endregion
#region Properties
[DataMember]
public virtual long MessageID
{
get { return _messageID; }
set { this._messageID = value; }
}
[DataMember]
public virtual DateTime? DateCreated
{
get { return _dateCreated; }
set { this._dateCreated = value; }
}
[DataMember]
public virtual DateTime? DatePublished
{
get { return _datePublished; }
set { this._datePublished = value; }
}
[DataMember]
public virtual int SourceID
{
get { return _sourceID; }
set { this._sourceID = value; }
}
[DataMember]
public virtual User User
{
get
{
if (this._user != null)
{ return this._user; }
else { return new User(); }
}
set { this._user = value; }
}
#endregion
}
}
se puede enviar el código de mensaje base? – hackerhasid
actualizado.Espero que ayude – CountCet