代码改变世界

使用NHibernate(6)-- HQL && ICriteria 简单介绍

  FuzhePan  阅读(612)  评论(0编辑  收藏  举报

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》

clipboard

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》

clipboard[1]

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

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

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示