中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

?Hibernate的QBC查詢方法怎么使用

發布時間:2022-09-29 16:54:51 來源:億速云 閱讀:140 作者:iii 欄目:開發技術

這篇文章主要介紹“Hibernate的QBC查詢方法怎么使用”,在日常操作中,相信很多人在Hibernate的QBC查詢方法怎么使用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Hibernate的QBC查詢方法怎么使用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

QBC(Query By Criteria)查詢

? Criteria對象提供了一種面向對象的方式查詢數據庫。Criteria對象需要使用Session對象來獲得。

? 一個Criteria對象表示對一個持久化類的查詢。

查詢所有

session.beginTransaction();
Criteria c = session.createCriteria(User.class);List<User> userList = c.list();for(User user:userList){
System.out.println(user.getUserName());
}
session.getTransaction().commit();

where

session.beginTransaction();
Criteria c = session.createCriteria(User.class);
c.add(Restrictions.eq("userName", "James"));
List<User> userList = c.list();for(User user:userList){
System.out.println(user.getUserName());
}
session.getTransaction().commit();

Restrictions對象

方法名稱 對應SQL中的表達式
----------------------------------------------------------
Restrictions.eq field = value
Restrictions.gt field > value
Restrictions.lt field < value
Restrictions.ge field >= value
Restrictions.le field <= value
Restrictions.between field between value1 and value2
Restrictions.in field in(…)
Restrictions.and andRestrictions.or orRestrictions.like field like value

示例

Criteria c = session.createCriteria(User.class);
c.add(Restrictions.like("userName", "J"));
c.add(Restrictions.eq("id", 120));
c.add(Restrictions.or(Restrictions.eq("userName", "James"),
Restrictions.eq("userName", "Alex")));

獲取唯一記錄

session.beginTransaction();
Criteria c = session.createCriteria(User.class);
c.add(Restrictions.eq("id", 120));
User user = (User) c.uniqueResult();
System.out.println(user.getUserName());
session.getTransaction().commit();

分頁

Criteria c = session.createCriteria(User.class);
c.setFirstResult(0);
c.setMaxResults(5);

分組與統計

session.beginTransaction();
Criteria c = session.createCriteria(User.class);
c.setProjection(Projections.sum("id"));
Object obj = c.uniqueResult();
System.out.println(obj);
session.getTransaction().commit();

Projections對象

方法名稱 描述-------------------------------------------------------Projections.sum 等于SQL中聚合函數sumProjections.avg 等于SQL中聚合函數avgProjections.count 等于SQL中聚合函數countProjections .distinct 去除重復記錄Projections.max 等于SQL中聚合函數maxProjections.min 等于SQL中聚合函數minProjections .groupProperty 對指定的屬性進行分組查詢

多個統計與分組

session.beginTransaction();
Criteria c = session.createCriteria(User.class);
ProjectionList projectionList = Projections.projectionList();
projectionList.add(Projections.sum("id"));
projectionList.add(Projections.min("id"));
c.setProjection(projectionList);// 和HQL一樣,單列用Object,多列用Object[]Object[] obj = (Object[]) c.uniqueResult();
System.out.println("sum:" + obj[0]);
System.out.println("min:" + obj[1]);

排序

Criteria c = session.createCriteria(User.class);
c.addOrder(Order.desc("id"));

到此,關于“Hibernate的QBC查詢方法怎么使用”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

旬邑县| 呼伦贝尔市| 老河口市| 璧山县| 县级市| 贡嘎县| 鄯善县| 当涂县| 东光县| 耒阳市| 新营市| 驻马店市| 乌拉特前旗| 兴业县| 花莲市| 新河县| 牡丹江市| 蒙阴县| 郎溪县| 天门市| 水富县| 陆良县| 新化县| 尤溪县| 桦川县| 积石山| 黄陵县| 安塞县| 宜阳县| 西吉县| 静宁县| 北海市| 柏乡县| 舟曲县| 凤山县| 海兴县| 于都县| 汝城县| 五原县| 沅江市| 麻江县|