日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Hibernate 统计记录总数方法汇总

發布時間:2025/5/22 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Hibernate 统计记录总数方法汇总 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
/***?@TODO:查詢某一年度的所有計劃數量*/publicint?findCountByYear(String?currYear)?{??String?hqlString?=?"select?count(*)?from?WaterPlan?as?pwhere?p.planYear?='"+currYear+"'";??Query?query?=?this.getSession().createQuery(hqlString);??return?((Number)query.uniqueResult()).uniqueResult();??}


??從Hibernate 3.0.x/3.1.x升級到最新的3.2版之后,3.2版的很多sql函數如count(), sum()的唯一返回值已經從Integer變為Long,如果不升級代碼,會得到一個ClassCastException。

??這個變化主要是為了兼容JPA,可以在hibernate.org的最新文檔中找到說明。

Hibernate Team也提供了一個與原來兼容的解決方案:

???Configuration?classicCfg?=?new?Configuration();??classicCfg.addSqlFunction(?"count",?new?ClassicCountFunction());??classicCfg.addSqlFunction(?"avg",?new?ClassicAvgFunction());??classicCfg.addSqlFunction(?"sum",?new?ClassicSumFunction());??SessionFactory?classicSf?=?classicCfg.buildSessionFactory();

???//int?count?=?((Integer)query.uniqueResult()).intValue();//改成int?count?=?((Number)query.uniqueResult()).intValue();??//這樣就可以兩個版本同時兼容.//參考代碼//第一種方法:String?hql?=?"select?count(*)?from?User?as?user";??Integer?count?=?(Integer)getHibernateTemplate().find(hql).listIterator().next();??return?count.intValue();??//第二種方法:String?hql?=?"select?count(*)?from?User?as?user";??return?((Integer)getHibernateTemplate().iterate(hql).next()).intValue();??//第三種方法:String?hql?=?"select?count(*)?from?User?as?user";??Query?query?=??getHibernateTemplate().createQuery(?getSession(),hql);??return?((Integer)query.uniqueResult()).intValue();



轉載于:https://blog.51cto.com/jiyanle/1200572

總結

以上是生活随笔為你收集整理的Hibernate 统计记录总数方法汇总的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。