row_number()在hql中的分区
发布时间:2020-11-17 14:49:21 所属栏目:Windows 来源:互联网
导读:在hql中,row_number()相当于分区的含义 我在hql中有以下查询: select s.Companyname, p.Productname, sum(od.Unitprice * od.Quantity - od.Discount) as SalesAmount FROM OrderDetails as od inner join od.Orders as o inner join o
在hql中,row_number()相当于分区的含义
select s.Companyname,p.Productname,sum(od.Unitprice * od.Quantity - od.Discount) as SalesAmount FROM OrderDetails as od inner join od.Orders as o inner join od.Products as p " + "inner join p.Suppliers as s" + " where o.Orderdate between '2010/01/01' and '2014/01/01' GROUP BY s.Companyname,p.Productname" 我想通过s.Companyname进行分区,其中RowNumber< = n. 据我所知,你不能在 HQL和 JPQL中使用row_number().我建议在这种情况下使用 native SQL查询:@PersistenceContext protected EntityManager entityManager; ... String sQuery = "SELECT q.* FROM (" + "SELECT s.company_name," + "p.product_name," + "sum(od.unit_price * od.quantity - od.discount) as SalesAmount," + "row_number() OVER (partition by s.company_name) as rn " + "FROM OrderDetails od " + "INNER JOIN Orders o ON o.id = od.order_id " + "INNER JOIN Products p ON p.id = od.product_id " + "INNER JOIN Suppliers s ON s.id = p.supplier_id " + "WHERE o.order_date between '2010/01/01' and '2014/01/01') as q " + "WHERE rn <= :n"; List<ResultDbo> results = new ArrayList<>(); Query query = entityManager.createNativeQuery(sQuery); query.setParameter("n",n); List<Object[]> resultSet = query.getResultList(); for (Object[] resultItem : resultSet) { ResultDbo result = new ResultDbo(); result.setCompanyName((String) resultItem[0]); result.setProductName((String) resultItem[1]); result.setSalesAmount((String) resultItem[2]); results.add(result); } 如果您尝试在HQL中使用OVER(),您几乎肯定会得到一些验证异常,例如java.lang.IllegalArgumentException:org.hibernate.hql.internal.ast.QuerySyntaxException:意外令牌:在第1行第42列附近. .. (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- Windows Mobile 6.5手势和C#2.0应用程序
- windows-installer – installshield和windowsinstaller之间
- Windows调试工具入门 — windebug
- api – Windows Phone应用程序中的捐赠
- windows-runtime – 将Action绑定到XAML中UserControl的属性
- Windows/Linux命令查看文件MD5,SHA1,SHA256 文件校验
- 如何使Windows Forms .NET应用程序显示为托盘图标?
- php在windows环境下获得cpu内存实时使用率(推荐)
- Windows Server 2016-WinSer 2016标准版与数据中心版的区别
- windows – 是否可以以编程方式找出通过网络锁定文件的进程
推荐文章
站长推荐
- windows10 安装python.msi出现error 2502/2503解
- windows-phone-8 – 使用WNS for windows phone
- resolveLocalFileSystemURI错误代码5 windows ph
- windows – 使用cmd提示符搜索谷歌或其他搜索引擎
- 在非Qt应用程序中使用基于Qt的DLL
- Windows系统·添加Python import 的库/模块路径
- windows-phone-8 – 启动TaskHost.exe失败,尝试运
- 如何使用GUI独立于.NET或其他Libs为Windows制作便
- windows-installer – 安装期间的错误代码2753
- windows – 如何通过apt-cyg安装cygwin / X
热点阅读