zoukankan      html  css  js  c++  java
  • NHibernate中多表(对象)间的查询

    在Nhibernate中,采用了HQL语言的查询方式,这种带有OO色彩的查询方式与传统的SQL查询有一些不同之处。 这一点,从它的语法可以看出来,http://www.hibernate.org/Documentation/HQLBNF
    一个比较简单的查询代码如下:
       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的文档。

  • 相关阅读:
    vscode的一些常用、神奇操作
    vue2.x中使用v-model进行父传子
    js设置,获取,删除cookies
    Linux虚拟机克隆后网卡UUID问题
    jQuery ajax 请求HttpServlet返回[HTTP/1.1 405 Method not allowed]
    byte、二进制、十进制数值之间的转换
    sqlite-jdbc jar包下载过程笔记
    windows系统bat方式启动tomcat出现java.lang.OutOfmemoryError:PermGen Space 错误
    DIV内容垂直居中
    在HTML中实现和使用遮罩层
  • 原文地址:https://www.cnblogs.com/wljcan/p/18073.html
Copyright © 2011-2022 走看看