Fluent NHibernate Composite ID table problem
Soy un poco nuevo en nhibernate y me encontré con un problema. Tengo las siguientes tablas:
Tabla 1 Nombre de la tabla Usuarios, Columna 1: CARNÉ DE IDENTIDAD, Columna 2: Nombr
Tabla 2 Nombre de la tabla Misiones, Columna 1: CARNÉ DE IDENTIDAD, Columna 2: Descripción
Tabla 3 Nombre de la tabla UserToDoMissions, Columna 1: ID de usuario, Columna 2: MissionID, Columna 3: Rango
Aquí está el código: MissionMap:
public class MissionMap : ClassMap<Mission>
{
public const string TableName = "tblMissions";
public const string c_id = "achID";
public const string c_name = "achName";
public MissionMap()
{
Table(TableName);
Id(x => x.ID).Column(c_id).Not.Nullable();
Map(x => x.Name).Column(c_name).Not.Nullable();
HasMany(x => x.UserToDoList).Cascade.All().Inverse().KeyColumn(UserToDoMap.c_missionID);
}
}
Mapa del usuario:
public class UserMap : ClassMap<User>
{
public const string TableName = "tblUsers";
public const string c_id = "usrID";
public const string c_userName = "usrUserName";
public UserMap()
{
Table(TableName);
Id(x => x.ID).Column(c_id).Not.Nullable();
Map(x => x.UserName).Column(c_userName).UniqueKey(DBConsts.UniqueKeys.User_UserName).Not.Nullable();
HasMany(x => x.UserToDoList).Cascade.All().Inverse().KeyColumn(UserToDoMap.c_userID);
}
}
UserToDo Map:
public class UserToDoMap : ClassMap<UserToDo>
{
public const string TableName = "tblToDoList";
public const string c_userID = "tdlUserID";
public const string c_missionID = "tdlMissionID";
public const string c_rank = "tdlRank";
public UserToDoMap()
{
Table(TableName);
CompositeId().KeyReference(x => x.User, c_userID).KeyReference(x => x.Achievment, c_missionID);
References(x => x.User).Column(c_userID).Cascade.All().UniqueKey(DBConsts.UniqueKeys.ToDoList_UserRanks).Not.Nullable();
References(x => x.Mission).Column(c_missionID).Cascade.All().Not.Nullable();
Map(x => x.Rank).Column(c_rank).UniqueKey(DBConsts.UniqueKeys.ToDoList_UserRanks).Not.Nullable();
}
}
Mi problema es que no puedo guardar una nueva línea. Puedo seleccionar y obtener todas las cosas pero no puedo guardar. ¿Algunas ideas
Gracias
Edit: no obtengo nada. No se produce ninguna excepción, pero la fila no se agrega a la base de datos. Por cierto, estoy usando el método de guardar en el objeto UserToDo.
Edit 2: después de docmanhattan responda aquí está el código:
UserToDoMap:
public class UserToDoMap : ClassMap<UserToDo>
{
public const string TableName = "tblToDoList";
public const string c_userID = "tdlUserID";
public const string c_missionID = "tdlMissionID";
public const string c_rank = "tdlRank";
public UserToDoMap()
{
Table(TableName);
CompositeId<UserToDoId>(x => x.ID)
.KeyReference(x => x.UserIdPart, c_userID)
.KeyReference(x => x.MissionIdPart, c_missionID);
References(x => x.ID.UserIdPart).Column(c_userID).Cascade.All().UniqueKey(DBConsts.UniqueKeys.ToDoList_UserRanks).Not.Nullable();
References(x => x.ID.MissionIdPart).Column(c_missionID).Cascade.All().Not.Nullable();
Map(x => x.Rank).Column(c_rank).UniqueKey(DBConsts.UniqueKeys.ToDoList_UserRanks).Not.Nullable();
}
}
UserToDoId entidad:
public class UserToDoId
{
public virtual User UserIdPart { get; set; }
public virtual Mission MissionIdPart { get; set; }
public override bool Equals(object obj)
{
UserToDoId recievedObject = (UserToDoId)obj;
if ((UserIdPart.ID == recievedObject.UserIdPart.ID) &&
(MissionIdPart.ID == recievedObject.MissionIdPart.ID))
{
return (true);
}
return (false);
}
public override int GetHashCode()
{
return base.GetHashCode();
}
}
UserToDo entidad:
public class UserToDo
{
public virtual UserToDoId ID { get; set; }
public virtual int Rank { get; set; }
public UserToDo()
{
}
public override bool Equals(object obj)
{
UserToDo recievedObject = (UserToDo)obj;
if ((ID.UserIdPart.ID == recievedObject.ID.UserIdPart.ID) &&
(ID.MissionIdPart.ID == recievedObject.ID.MissionIdPart.ID) &&
(Rank == recievedObject.Rank))
{
return (true);
}
return (false);
}
public override int GetHashCode()
{
return base.GetHashCode();
}
}
Recibo la excepción cuando intento crear la fábrica de sesiones:
{"No se pudo encontrar un captador para la propiedad 'UserIdPart' en la clase 'DatabaseEntities.UserToDo'"}