zoukankan      html  css  js  c++  java
  • 使用NHibernate(6)-- HQL && ICriteria 简单介绍

    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中也有相同的使用方法。

  • 相关阅读:
    服务器安全之修改3389远程桌面端口小工具(包源码)
    CYQ.Data.ProjectTool 项目配置工具发布(包源码)
    爱奇艺视频广告拦截失败,发文共商大计
    开发者基础知识游戏,共10关,欢迎挑战
    秋天新作品:秋式广告杀手,每年帮大伙多活78天!
    MySql Blob图片类型存储Bug解决:索引超出了数组界限错误
    爱奇艺视频广告拦截失败,发文共商大计
    简说宽带商的弹窗广告进化及网站应对之策(DNS劫持进化论)
    秋式广告杀手技术分享:网络请求基础知识
    通用社区登陆组件技术分享(开源)中篇:OAuth 登陆组件流程及组件集成方法
  • 原文地址:https://www.cnblogs.com/FuzhePan/p/3652135.html
Copyright © 2011-2022 走看看