1

我是 MVC 应用程序的新手,我遇到了一个非常具体的问题。问题是,我有 2 个课程:“Paciente”和“Analises”。

public class Paciente
{
    public virtual Guid PacienteID { get; set; }
    public virtual string Nome { get; set; }
    public virtual string Sexo { get; set; }
    public virtual DateTime DataDeNasc { get; set; }
    public virtual int IdadeDiag { get; set; }

    public virtual IList<Analises> analises { get; set; } 
}


public class Analises
{
    public virtual Guid AnaliseID { get; set; } 
     // some analysiss values
    public virtual decimal afp { get; set; }
    public virtual decimal hemoglobina { get; set; }
    public virtual DateTime DataDaAnalise { get; set; }
    public virtual Paciente pac { get; set; } 

}

因此,一个患者有多个分析,每个分析都有一个患者(一对多)。

我已经用 NHIbernate 和 FluentNHibernate 映射了这个:

public PacienteMap()
    {
        Table("pacientes");
        Id(x => x.PacienteID).GeneratedBy.Guid();
        Map(x => x.Nome);
        Map(x => x.Sexo);
        Map(x => x.DataDeNasc).CustomType("Date");;
        Map(x => x.IdadeDiag);
        HasMany(m => m.analises).Not.KeyNullable().Fetch.Join().KeyColumn("pacienteid"); 
    }



 public AnalisesMap()
    {
        Table("analises");
        Id(x => x.AnaliseID).GeneratedBy.Guid();
        Map(x => x.afp);
        Map(x => x.hemoglobina);
        Map(x => x.DataDaAnalise).CustomType("Date");
        References(x => x.pac).ForeignKey("pacienteid").Not.Nullable();
    }

我的问题是我正在使用 jTable 来显示这一点。我想查看患者列表(并且有效),然后查看每个患者的分析列表(无效!)

我的控制器是这样的:

 [HttpPost]
    public JsonResult AnalisesList(Guid pacienteId)
    {
        try
        {

            var list_analises = AnalisesRepository.GetPacienteAnalises(pacienteId);   
            var all_analises = Mapper.Map<IEnumerable<Analises>, IEnumerable<AnalisesView>>(list_analises);
            List<AnalisesView> analises = all_analises.ToList();
            return Json(new { Result = "OK", Records = analises });

        }
        catch (Exception ex)
        {
            return Json(new { Result = "ERROR", Message = ex.Message });
        }
    }

我还使用自动映射器从数据库对象的对象视图中获取。

所以,现在,我的分析列表没有显示!我不知道为什么。GetPacienteAnalises 就像:

 public IList<T> GetPacienteAnalises (Guid pacienteId)
    {
        using (ISession session = SessionManager.OpenSession())
        {
            using (ITransaction transaction = session.BeginTransaction())
            {

                return session.CreateCriteria(typeof(T)).Add(Restrictions.Eq("pacienteid", pacienteId)).List<T>();

            }
        }  
    }

所以,我认为一切都很好......但我一直收到“无法解析属性:pacienteid:Infraestrutura.Models.Analises”。

4

1 回答 1

1

您的问题出在这一行:

return session.CreateCriteria(typeof(T))
    .Add(Restrictions.Eq("pacienteid", pacienteId))
    .List<T>();

我假设T在这种情况下是Analises. Analises没有名为 的属性pacienteid。相反,它有一个名为pac. 替换"pacienteid""pac.PacienteID"。创建条件时使用的字段应该是属性名称,而不是列名称。

return session.CreateCriteria(typeof(T))
    .Add(Restrictions.Eq("pac.PacienteID", pacienteId))
    .List<T>();

Paciente例如,如果您按除主键之外的其他列进行过滤Nome,则需要进行连接。在这种情况下,您会执行以下操作:

session.CreateCriteria(typeof(T))
    .CreateAlias("pac", "p")            // CreateAlias performs an inner join
    .Add(Expression.Eq("p.Nome", name))
    .List<T>()

但无需加入即可到达pac.PacienteID.

于 2013-10-30T18:43:13.880 回答