1,HQL。

HQL是NHibernate特有的查询方式,早先的java语法还没有类似Linq的Jinq,所以Hibernate就弄了一套自己的查询语言,NHibernate移植的时候把这种语言也一块儿移植过来了。这是一种和Sql差不多的语言,不同的是查询中的字段和实体名保持一致,而不是和数据库表列名保持一致。

下面的例子还是在之前那个小程序的基础上演示:

public User GetUserByName(string name)
{
var hql = @"select u from User u where u.Name=:name ";
return session.CreateQuery(hql).SetString("name",name);
}

这个示例从NH_User表中查找出指定名称的User。可以看到我们的hql语言中写的是User,而不是NH_User。另外,因为此处要查询的是一整个实体,所以可以简写成“from User u where u.Name=:name”。最后通过Session的CreateQuery方法创建一个查询,并给参数赋值。

类似的还支持 inner join,where,order by,group by,and or,delete,甚至是sql中的聚合函数sum等。

在来个批量删除的例子:

Session.CreateQuery("delete from User where Id> :Id")
.SetInt64("Id", id)
.ExecuteUpdate();

以下截图来自《Working with NHibernate 3.0》

2,ICriteria。

ICriteria是NHibernate标准查询接口。

先看一段原始的ICriteria查询:

ICriteria criteria = Session.CreateCriteria<User>(“u”)
.SetProjection(Projections.ProjectionList()
.Add(Projections.Property(“u.Id”))
.Add(Projections.Property(“u.Name”));

对应的sql语句如下:

select u.Id,u.Name from User u

从上面的查询可以看出ICriterria用起来是非常麻烦的,于是NHibernate3.0之后对ICriteria进行了扩展,添加了QueryOver方法,使用起来和linq+lambda的方式差不多。下面是使用QueryOver方法的示例:

Session.QueryOver<User>().where(u=>u.Id>3).OrderBy(u=>u.Name).List();

类似where方法,还支持Inner.JoinQueryOver<T>、SingleOrDefault等和linq非常相似的方法。

下图来自《Working with NHibernate3.0》

3,另外还有综合查询(MultiQuery)和命名查询(Name Queries),不常用,所以不打算介绍。

Futures查询在上一篇linq to Nhibernate中已经介绍,HQL和ICriteria中也有相同的使用方法。

最新文章

  1. const 引起的BUG
  2. sqoop、flume 安装
  3. DSP基础学习-ADC同步采样
  4. IE和FireFox中JS兼容之event .
  5. uboot 的内存命令使用 mw (修改) md (显示)
  6. oracle跟踪事件(dump)总结
  7. 什么是CSS清除浮动?
  8. SQL2012远程连接到SQL2008时的问题:已成功与服务器建立连接,但在登陆过程中发生错误。
  9. LeetCode题解——3Sum
  10. Python SqlAlchemy使用方法
  11. OpenStack项目列表
  12. IOS开发之UIView总结
  13. mac下搭建cordova开发环境
  14. Java面试题——中级(下)
  15. 2018-2019-2 网络对抗技术 20165328 Exp1 PC平台逆向破解
  16. 读书笔记二 How Does the Internet work?
  17. 【PMP】项目浮动的三种时间
  18. 深度学习原理与框架-神经网络-线性回归与神经网络的效果对比 1.np.c_[将数据进行合并] 2.np.linspace(将数据拆成n等分) 3.np.meshgrid(将一维数据表示为二维的维度) 4.plt.contourf(画出等高线图,画算法边界)
  19. memory prefix vice ,with out 1
  20. Robolectric测试框架使用笔记

热门文章

  1. [转]如何创建一个自签名的SSL证书(X509)
  2. IntelliJ IDEA 2017版开发SpringBoot之fastJsonHttpMessageConvert使用
  3. BASE64Encoder及BASE64Decoder编译器找不到问题
  4. Redis是可以安装成windows服务-开机自启 win7 64位
  5. I-Keyboard
  6. 单链表(带random指针)深拷贝(Copy List with Random Pointer)
  7. Tomcat 系统架构与设计模式1
  8. Sharepoint安装的几处注意事项
  9. Selenium框架切换-----Selenium快速入门(七)
  10. 当我们在谈论multidex65535时,我们在谈论什么