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的文档。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗