• NHibernate中多表(对象)间的查询


     

    一个比较简单的查询代码如下:
       IList userList=session.Find (" from testMSSql.student as student where student.Name=?","张三", NHibernate.NHibernate.String);
       上面的代码,表示从testMSSql.student对象表中查询姓名为 "张三"的学生

    如果涉及到多对象间的连接查询,代码如下:
       IList userList=session.Find (" from student  s left outer join s.Teacher as t where t.TeacherName='tom'");
    查询老师姓名为“tom”的学生。
     

       在测试的时候,我是将返回的结果绑定到DataGrid中,结果显示正常,但是使用下面这种方式就有问题了:
      IList userList=session.Find ("select s.Name,t.TeacherName from student  s left outer join s.Teacher as t where t.TeacherName='ee' ");
     在绑定到DataGrid时,显示的是IList中每个对象的属性,如 Rank,IsReadOnly等,而不是脚本中需要的Name,TeacherName,这是什么原因呢?

      仔细比较了两个IList,在没有使用Select的时候,返回的是一个 Student对象,否则返回的是一个对象数组( Object[]),因此在绑定到DataGrid的时候出现了问题  。

     在HQL语言中有这样的一个语法:   NEW className OPEN selectedPropertiesList CLOSE 
    即:可以将查询出来的属性组建成一个新的类,如:
    select  new StudentInfo(s.Name,t.TeacherName) from student  s left outer join s.Teacher as t where t.TeacherName='ee' , 但是我再尝试的过程中发现 新的类必须是持久的,也就是说必须实现StudentInfo及其hbm.xml文件,这也就失去意义了。

    Nhibernate的文档太少,只能自己模索,现在不得不开始看Hibernate的文档。

  • 相关阅读:
    ETL工具主流产品
    深入了解当前ETL中用到的一些基本技术
    用C#实现通用守护进程
    80端口被system占用的问题
    Python Web 性能和压力测试 multi-mechanize
    [python]用profile协助程序性能优化
    python代码优化技巧
    转:Java学习路线图
    SecureCRT 颜色
    深度学习(Deep Learning)算法简介
  • 原文地址:https://www.cnblogs.com/yexinw/p/3474013.html
Copyright © 2020-2023  润新知