當前位置:首頁 » 編程語言 » hibernatesql查詢分頁查詢

hibernatesql查詢分頁查詢

發布時間: 2023-07-11 01:35:34

㈠ hibernate中純sql語句查詢,當分頁的時候會第二頁以後會多出一列行號(包含第二頁)

hibernate 分頁查詢的時候會將你的查詢語句結果作為結果集然後在此之上查詢*
select * from (***********) where rownum<30(←這是第一頁每頁三十個)
select * from
(
select * from (***********) where rownum<60
)
where rownum_>30(←這是第二頁每頁三十個)
所以多出來一列 具體解決方式....... 我也不太清楚我也碰到了這個問題 原因找到了 我正在想辦法處理

㈡ hibernate的三種查詢方式

1.1、SQL概述

HQL是Hibernate Query Language的縮寫,提供更加豐富靈活、更為強大的查詢能力;HQL接近SQL`語句查詢語法。

完整的HQL語句形式如下:

select | update | delete … from … where … group by … having … order by … asc|desc

其中的update、delete為Hibernate3中所新添加的功能,可見HQL查詢非常類似於標准SQL查詢。HQL查詢在整個Hibernate實體操作體系中占核心地位。

String hql = "HQL語句";

Query query = session.createQuery(hql);

List list = query.list(); //查詢得到多個實體對象集合

Object result = query.uniqueResult(); //查詢得到一個實體對象

int x = query.executeUpdate(); //執行update或delete語句悄陵,返回數據表受影響行數

1.2、實體查詢

查詢過程中表名使用類名,列名使用屬性名,類名和屬性名稱區分大小寫

String hql="from Users";//from 實體類類型名稱

Query query = session.createQuery(hql);

List<Users> list = query.list();

for (Users user : list) {

    System.out.println(user);

}

1.3、帶where的查詢

Query query = session.createQuery("from Users where uid=3");

Users user = (Users) query.uniqueResult();//uniqueResult 單一對象

System.out.println(user);

Query query = session.createQuery("from Users where uid>5");

List<燃雹Users>皮運帆 list = query.list();

for (Users user : list) {

    System.out.println(user);

}

1.3、屬性查詢

查詢部分屬性

String hql="select u.uid,u.uname,u.upwd from Users u where u.uname='張三'";

Query query = session.createQuery(hql);

List<Object[]> list = query.list();

for (Object[] objects : list) {

    System.out.println(Arrays.toString(objects));

}

String hql="select new Users(u.uname,u.upwd) from Users u where u.uname='張三'";

Query query = session.createQuery(hql);

List<Users> list = query.list();

for (Users user : list) {

    System.out.println(user);

}

1.4、實體的更新和刪除

從hibernate 3版本開始才支持

//更新

String hql="update Users set uname='王五',upwd='321' where uid=3";

int res = session.createQuery(hql).executeUpdate();

//刪除

String hql="delete from Users where uid=3";

int res = session.createQuery(hql).executeUpdate();

/*

返回值結果:

正整數:表受影響的行數據

0: 語句正常執行,但沒有行受影響

負整數:通常是-1,執行HQL語句是一條查詢語句

*/

HQL語句不能做添加

1.5、分組與排序

排序

處理方式和SQL語句中的排序是一樣的

String hql="from Users order by uid";

Query query = session.createQuery(hql);

List<Users> list = query.list();

for (Users user : list) {

    System.out.println(user);

}

order by語句只能出現在語句的最後位置

分組

處理方式和SQL語句中分組查詢相同

分組語句需要處理篩選,只能使用having語句,而不能使用where語句。

String hql = "select e.dept.deptno, count(e) from Emp e group by dept.deptno";

String hql = "select e.dept.deptno, count(e) from Emp e group by dept.deptno having count(e)>=5";

1.6、參數綁定

使用佔位參數

String hql="from Users where uid=? or uname=?";

Query query = session.createQuery(hql);

//索引從0開始

query.setInteger(0, 3);//query.setParameter(0, 3);

query.setString(1, "張三");//query.setParameter(1, "張三");

List<Users> list = query.list();

for (Users user : list) {

    System.out.println(user);

}

使用參數名稱

String hql = "from Users where uid=:no1 or uid=:no2";

Query query = session.createQuery(hql);

query.setInteger("no1", 1);

query.setInteger("no2", 3);

//....

可以使用點位參數和名稱參數混合使用

String hql = "from User where uid=? or uid=:no2";

Query query = session.createQuery(hql);

query.setInteger(0, 7788);

query.setInteger("no2", 7566);

//....

//使用點位參數和名稱參數混合使用,所有點位參數必須放在前面,一旦有名稱參數出現,其後將不能再出現佔位參數

1.7、連接查詢

--SQL語句:查詢員工姓名、薪資、部門名稱

SELECT ENAME,SAL,DNAME

FROM EMP e JOIN DEPT d ON e.DEPTNO=d.DEPTNO

SELECT ENAME,SAL,DNAME FROM EMP,DEPT WHERE EMP.DEPTNO=DEPT.DEPTNO

沒有on語句

能被連接到查詢中的必須是主查詢對象的子屬性

String hql="SELECT e.ename, e.sal, e.dept.dname FROM Emp e";

//HQL連接查詢

String hql="SELECT e.ename, e.sal, d.dname FROM Emp e JOIN e.dept d";

String hql = "SELECT e FROM Emp e JOIN e.dept"; //JOIN將沒有意義

String hql = "FROM Emp e JOIN e.dept";

Query query = session.createQuery(hql);

List<Object[]> list = query.list();

//List集合中的數組中會保存兩個元素:

//0:主數據(Emp)

//1:從數據(Dept)

//查詢編號為7788的員工信息,同時將對應的dept信息和manager信息查詢並保存在對應的子屬性中

String hql = "FROM Emp e JOIN FETCH e.dept d JOIN FETCH e.manager m WHERE e.empno=7788";

Query query = session.createQuery(hql);

Emp emp = (Emp) query.uniqueResult();

System.out.println(emp);

System.out.println(emp.getManager());

System.out.println(emp.getDept());

1.8、分頁

String hql = "from Users";

Query query = session.createQuery(hql);

query.setFirstResult(0);

query.setMaxResults(2);

2、QBC查詢

QBC(Query By Criteria)查詢就是通過使用Hibernate提供的Query By Criteria API來查詢對象,這種API封裝了SQL語句的動態拼裝,對查詢提供了更加面向對象的功能介面。

QBC查詢最重要的三個類:

Restrictions 條件限制

Projections 列設射

Order 排序

2.1、查詢實現

Criteria criteria = session.createCriteria(Users.class);

//session.createCriteria("entity.Users");

//session.createCriteria(Users.class, "別名");

List<Dept> list = criteria.list();

//查詢單行結果(如果結果有兩行或更多,會報錯)

Object uniqueResult = criteria.uniqueResult();

2.2、Projections 列投射

語法:

//查詢uname屬性

Criteria criteria = session.createCriteria(Users.class);

PropertyProjection property = Projections.property("name");

criteria.setProjection(property);

List<Object> result = criteria.list();

//查詢uname, upwd屬性

Criteria criteria = session.createCriteria(Users.class);

//1.創建投射列表

ProjectionList projectionList = Projections.projectionList();

//2.向投射列表中添加列投射

PropertyProjection property1 = Projections.property("uname");

PropertyProjection property2 = Projections.property("upwd");

projectionList.add(property1).add(property2);

//3.將投射列表設置到准則中

criteria.setProjection(projectionList);

List<Object> result = criteria.list();

返回值類型 方法名稱 描述

PropertyProjection Projections.property 指定某屬性

AggregateProjection Projections.avg 求平均值

CountProjection Projections.count 統計某屬性的數量

CountProjection Projections.countDistinct 統計某屬性不同值的數量

PropertyProjection Projections.groupProperty 指定某個屬性為分組屬性

AggregateProjection Projections.max 求最大值

AggregateProjection Projections.min 求最小值

ProjectionList Projections.projectionList 創建一個ProjectionList對象

Projection Projections.rowCount 查詢結果集中的記錄條數

AggregateProjection Projections.sum 求某屬性的合計

2.3、Restrictions 條件限制

語法:

Criteria criteria = session.createCriteria(Users.class);

Criterion notNull = Restrictions.isNotNull("comm");

criteria.add(notNull); //添加一個條件(如果添加了多個條件,默認條件之間使用and連接)

List<Users> list = criteria.list();

返回值類型 方法名稱 描述

SimpleExpression Restrictions.eq 等於(equal)

Criterion Restrictions.allEq 使用Map,Key/Valu進行多個等於的比對

SimpleExpression Restrictions.gt 大於(great than)

SimpleExpression Restrictions.ge 大於等於(great than or equal)

SimpleExpression Restrictions.lt 小於(less than)

SimpleExpression Restrictions.le 小於等於(less than or equal)

Criterion Restrictions.between 對應SQL的between

SimpleExpression Restrictions.like 對應SQL的like

Criterion Restrictions.in 對應SQL的in

LogicalExpression Restrictions.and and關系

LogicalExpression Restrictions.or or關系

Criterion Restrictions.isNull 為空

Criterion Restrictions.sqlRestriction SQL限定查詢

Criterion Restrictions.not 取反

2.3、Order排序

語法:

Criteria criteria = session.createCriteria(Dept.class);

criteria.addOrder(Order.asc("name"))

.addOrder(Order.desc("loc"));

//SELECT * FROM DEPT ORDER BY name ASC, loc DESC

返回值類型 方法名稱 描述

Order Order.asc(String propertyName) 升序

Order Order.desc(String propertyName) 降序

2.4、分頁查詢

Criteria criteria = session.createCriteria(Dept.class);

int pageNum = 2, pageSize = 5;

criteria.setFirstResult((pageNum-1)*pageSize); //查詢起始行下標

criteria.setMaxResults(pageSize); //查詢的最大行數

List list = criteria.list();

//setFirstResult方法和setMaxResults方法同樣可以在SQLQuery及Query類型上使用

3、原生SQL查詢

1、查詢

String sql = "select uid,uname,upwd from _users";

List list = session.createSQLQuery(sql).list();

for(Object obj : list){

    System.out.println(obj);

}

2、 addEntity()

String sql = "select uid,uname,upwd from _users";

// addEntity()可以告訴Hibernate你想要封裝成對象的類型,然後自動為你封裝

SQLQuery query = session.createSQLQuery(sql).addEntity(Users.class);

List<User> list = query.list();

for(Users user : list){

System.out.println(user.getUname());

}

3、 uniqueResult

String sql = "select uid,uname,upwd from _users where uid = 2";

SQLQuery query = session.createSQLQuery(sql).addEntity(Users.class);

Users user = (Users) query.uniqueResult();//返回單一對象

System.out.println(user.getUname());

USB Microphone https://www.soft-voice.com/

Wooden Speakers  https://www.zeshuiplatform.com/

亞馬遜測評 www.yisuping.cn

深圳網站建設www.sz886.com

㈢ hibernate的sqlquery分頁,尾頁會出現上一頁的數據

您好
估計是你的起始頁沒有控制住,showPage這個值應該沒有變化或影響的。
debug一下,看看翻頁的時候的時候,showPage這個值有沒有變化。
希望對你有幫助。

㈣ hibernate訪問oracle分頁SQL語句rownum子查詢問題

第一個是從第幾條開始,第二個是每頁幾條。
你看看你資料庫裡面的數據夠不夠分頁,你這樣只寫兩句就分頁是不夠的。
page = Paginator.showPage(, hql, paramValues, pageCurrent, pageSize);

/*
* 利用hql實現翻頁
*/
public static Page showPage(PersistentBaseDao p, String hql,
Object[] paramValues, int pageCurrent, int pageSize) {
// 入口參數校驗(無)
if (p == null) {
// log.debug("Paginator.p.hql is Empty");
}
if (hql.equals("") || hql == null) {
// log.debug("Paginator.showPage.hql is Empty");
}
if (p == null) {
// log.debug("Paginator.showPage.p is Empty");
}
PersistentBaseDao = (PersistentBaseDao) p;
// 如果當前頁大於>總的頁數,則讓當前頁等於總頁數
int tempPageCount =0;

if (paramValues == null) {
tempPageCount = .getPageCount(hql, (Object[]) null, pageSize);
} else {
tempPageCount= .getPageCount(hql, paramValues, pageSize);
}
if (pageCurrent > tempPageCount) {
pageCurrent = tempPageCount;
}
// 如果當前頁大於<1,則讓當前頁等於1
if (pageCurrent < 1) {
pageCurrent = 1;
}
// 調用.serarch()方法
if (paramValues == null) {
page = .search(hql, pageCurrent, pageSize);
} else {
page = .search(hql, paramValues, pageCurrent, pageSize);
}
// 為page對象設置當前頁的屬性
page.setPageCurrent(pageCurrent);
// 將page對象放在request對象中
return page;
}

/*
* 利用List實現翻頁
*/
@SuppressWarnings("unchecked")
public static Page showPage(List list, int pageCurrent, int pageSize) {
// 入口參數校驗(無)
if (list.isEmpty()) {
// log.debug("Paginator.showPage.list is Empty");
}
// 如果當前頁大於>總的頁數,則讓當前頁等於總頁數
if (pageCurrent > page.getPageCount()) {
pageCurrent = page.getPageCount();
}
// 如果當前頁大於<1,則讓當前頁等於1
if (pageCurrent < 1) {
pageCurrent = 1;
}
List ls = new ArrayList();
// 根據得到的list轉化為page對象
if (list.size() % pageSize == 0) {
page.setPageCount((list.size() / pageSize));
} else {
page.setPageCount((list.size() / pageSize) + 1);
}
page.setPageCurrent(pageCurrent);
page.setRecordCound(list.size());
int stag = (pageCurrent - 1) * pageSize;
int etag = pageCurrent * pageSize;
for (int i = stag; i < list.size() && i < etag; i++) {
ls.add(list.get(i));
}
page.setDataList(ls);
return page;
}

㈤ hibernate分頁查詢的時候是把數據全部查出來嗎還是需要那一頁查那一頁呢

當然是查詢每頁需要的數據了,hibernate分頁查詢是與基於sql語句的簡單分頁查詢道理是一樣的,有setFirstResult(int arg)設置起始數據位置,setMaxResults(int arg);設置當前頁所顯示的最大數據量,依賴前台傳回的頁碼變數進行數據交替從而實現分頁

熱點內容
中國首個具有世界影響力的編譯器 發布:2025-02-09 01:56:21 瀏覽:719
tomcat上傳超時 發布:2025-02-09 01:41:42 瀏覽:483
androidactivity豎屏 發布:2025-02-09 01:41:40 瀏覽:377
家庭配置怎麼合理 發布:2025-02-09 01:36:14 瀏覽:807
頭條軍事源碼 發布:2025-02-09 01:31:53 瀏覽:997
androidintent視頻 發布:2025-02-09 01:31:43 瀏覽:858
歐姆龍plc密碼如何設置 發布:2025-02-09 01:24:31 瀏覽:687
php支持jpeg 發布:2025-02-09 01:24:22 瀏覽:803
反編譯去注冊碼 發布:2025-02-09 01:19:48 瀏覽:887
安卓如何查找舊密碼 發布:2025-02-09 01:17:21 瀏覽:418