zoukankan      html  css  js  c++  java
  • LING与HQL(三)

    常用查询:
        LINQ:
          from c in ctx.Customers select c
        HQL:
           from Customers c 
      比较一下,区别还是有的 ;注意HQL中Customers 是个领域模型;LINQ中的ctx是DataContext实例;
      既然他们都是对象化的查询,那下面的例子:
         LINQ:
          from c in ctx.Customers
             where c.ContractorName == ”tom“  select new {obj = c.ContractorName}
        HQL:
           from Customers c where c.ContractorName = ?   
          // "?"表示传入的参数 ,上面的两个例子中的c都可以看成一个对象,
      在如:
          LINQ:
           from c in ctx.Customers 
               where c.Orders.Count > 0 select c
            //Customers 和 Orders 是主外键关系
          HQL:
           from Orders o where o. Customers.ContractorName = ?  
           //o表示Orders这个对象,它的属性Customers也是一个对象
          select Customers from Orders o where o. Customers.ContractorName = ?  
          //在HQL中可以通过select 返回其他对象

    使用排序:
         LINQ:
            from c in ctx.Employees 
               where c.Employees.Count >0
               orderby c.EmployeeID descending , c.ReportsTo ascending 
               select c
          注意,因为Employees 有个自链接,[ReportsTo] REFERENCES [EmployeeID],所以有c.Employees.Count >0
    这个;
         HQL:
            from Customers c order by c.EmployeeID desc, c.ReportsTo asc
        这里HQL的排序方式和T-SQL一样;

    使用分组:
        简单分组:
        LINQ:
          from c in ctx.Employees
            group c by c.ReportsTo
          select c
        HQL:
          from Employees e group by e.EmployeeID
      带条件的分组:
         LINQ:
          from c in ctx.Employees
            group c by c.ReportsTo into tmp
            where tmp.Count() > 0
          select new { 分组数 = tmp.Count()}
        HQL:
          select count(e) from Employees e
             group by e.EmployeeID 
             having  e.EmployeeID = 11
  • 相关阅读:
    剑指Offer
    剑指Offer
    剑指Offer
    面积(area)
    最少步数
    细胞
    集合的前N个元素
    1~100卡特兰数(存一下hhhh)
    [Codeforces137C]History(排序,水题)
    [Codeforces676B]Pyramid of Glasses(递推,DP)
  • 原文地址:https://www.cnblogs.com/pojia/p/1106270.html
Copyright © 2011-2022 走看看