NHibernate中多表(对象)间的查询
来源:互联网 发布:java项目毕业设计 编辑:程序博客网 时间:2024/06/06 19:37
在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的文档。
- NHibernate中多表(对象)间的查询
- NHibernate中多表(对象)间的查询
- NHibernate中多表(对象)间的查询
- 面向对象的NHibernate数据查询语言-HQL
- 面向对象的NHibernate数据查询语言-HQL
- 面向对象的NHibernate数据查询语言-HQL
- NHibernate 把查询出的对象转化为table
- NHibernate关联对象多表查询
- NHibernate Linq 的 join (联合查询) 的例子
- NHibernate 查询
- NHibernate 查询
- Nhibernate查询
- NHibernate的几种查询方式
- [NHibernate]一对多关系(关联查询)
- [NHibernate]一对多关系(关联查询)
- NHibernate的使用方法(新手)
- NHibernate查询、更新、删除
- NHibernate各种查询
- 你做到了吗?
- asp.net中打开文件的方法Response.WriteFile();
- 如何将窗体身份验证用于 Active Directory
- 发布:CtrlC源代码搜索引擎
- [转贴]色彩调和的原理
- NHibernate中多表(对象)间的查询
- 如何学习JBUILDER呢!敬请高手
- Asp.net中Application的使用
- 多媒体处理类
- The C++ Programming Language 第七章 作业
- 进行SWT开发前的环境设置
- 部分ADSL猫的默认密码
- 开源项目网址
- Observer