使用Query接口 Hql
條件查詢
hql與sql語句對比及查詢步驟
- 查詢?nèi)?/li>
String sql="select * from tb_user";
//直接from表所對應的實體類
String hql="from User";
- 條件查詢>索引占位符
String sql="select * from tb_user where id=?";
String hql="from User where id=?";
//獲取session對象。。。。。。假設已經(jīng)獲取
Query query=session.createQuery("from User where id=?");
//第一種設置參數(shù) 指定類型 第一個參數(shù)為?的位置
query.setInteger(0,3);
//第二種設置參數(shù)的方式 不設定指定類型
query.setParameter(0,3);
//獲取結(jié)果 多個結(jié)果時
List<User> list=query.list();
//獲取結(jié)果 單個結(jié)果時
User user=(User)query.uniqueResult();
- 條件查詢>命名占位符
//獲取session對象。。。。。。假設已經(jīng)獲取
Query query=session.createQuery("from User where id=:dd");
//設置占位符的值
query.setParameter("dd",3);
//獲取結(jié)果 多個結(jié)果時
List<User> list=query.list();
//獲取結(jié)果 單個結(jié)果時
User user=(User)query.uniqueResult();
- 條件查詢>命名占位符>多條件
- 命名與對象屬性名相同
//獲取session對象。。。。。。假設已經(jīng)獲取
Query query=session.createQuery("from User where id=:id and name=:name and age=:age");
//設置占位符的值 此時上面命名必須與類中屬性同名 id必須為:id
User user =new User();
user.setId(3);
user.setAge(26);
user.setName("zhangsan");
query.setProperties(user);
//獲取結(jié)果 多個結(jié)果時
List<User> list=query.list();
//獲取結(jié)果 單個結(jié)果時
User user=(User)query.uniqueResult();
- 命名與對象屬性名不相同
//獲取session對象。。。。。。假設已經(jīng)獲取
Query query=session.createQuery("from User where id=:d and name=:n and age=:a");
//設置占位符的值 此時上面命名可以隨便取
Map<String,Object> map=new HashMap<>();
map.put("d",3);
map.put("n","jack");
map.put("a",19);
query.setProperties(map);
//獲取結(jié)果 多個結(jié)果時
List<User> list=query.list();
//獲取結(jié)果 單個結(jié)果時
User user=(User)query.uniqueResult();
模糊查詢
String sql="select * from User where name like :name";
String hql="from User where name like :name";
//獲取session對象。。。。。。假設已經(jīng)獲取
Query query=session.createQuery("from User where name like :name");
//設置占位符的值
query.setParameter("name","%d%");
//獲取結(jié)果 多個結(jié)果時
List<User> list=query.list();
投影查詢
返回的時object數(shù)組 object[] 一般用于展示數(shù)據(jù),不持久化
Session session = HibernateUtil.getSession();
String hql="select id,name from Street";
Query query = session.createQuery(hql);
List<Object[]> list = query.list();
for (Object[] objects : list) {
System.out.println(Arrays.toString(objects));
}
session.close();
分頁查詢
sql,hql區(qū)別
String sql="select * from tb_user limit ?,?";
String hql="from User";
//獲取session對象。。。。。。假設已經(jīng)獲取
Query query=session.createQuery("from User");
//設置起始頁
query.setFirstResult(0);
//設置最大條數(shù)
query.setMaxResults(4);
//獲取查詢結(jié)果
List<User> list =query.list();
排序查詢
Session session = HibernateUtil.getSession();
String hql="from Street order by id desc";
Query query = session.createQuery(hql);
List<Street> list =query.list();
for (Street street : list) {
System.out.println(street);
}
session.close();
動態(tài)查詢
Session session = HibernateUtil.getSession();
String hql="from Street where 1=1";
StringBuffer buffer=new StringBuffer(hql);
Street street =new Street();
street.setId(2);
if(street.getId()!=0){
buffer.append(" and id=:id");
}
if(street.getName()!=null){
buffer.append(" and name=:name");
}
if(street.getDistrict_id()!=0){
buffer.append(" and District_id=:District_id");
}
Query query = session.createQuery(buffer.toString());
query.setProperties(street);
List<Street> list = query.list();
for (Street street2 : list) {
System.out.println(street2);
}
session.close();
使用criteria接口 QBC
不需要任何sql語句
條件查詢
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
// 等于
criteria.add(Restrictions.eq("id", 2));
// 小于等于
criteria.add(Restrictions.le("id", 2));
// 小于
criteria.add(Restrictions.lt("id", 2));
// 大于等于
criteria.add(Restrictions.ge("id", 2));
// 大于
criteria.add(Restrictions.gt("id", 2));
// 不等于
criteria.add(Restrictions.ne("id", 2));
// 在2者之間 包括兩端
criteria.add(Restrictions.between("id", 2, 3));
// id等于1,2,4
criteria.add(Restrictions.in("id", new Integer[] { 1, 2, 4 }));
// and 并列條件查詢
criteria.add(Restrictions.and(Restrictions.eq("id", 2),
Restrictions.eq("id", 3)));
// or 或條件查詢
criteria.add(Restrictions.or(Restrictions.eq("id", 2),
Restrictions.eq("id", 3)));
List<Street> list = criteria.list();
for (Street street : list) {
System.out.println(street);
}
session.close();
分頁查詢
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
criteria.setFirstResult(0);
criteria.setMaxResults(3);
List<Street> list = criteria.list();
for (Street street : list) {
System.out.println(street);
}
session.close();
模糊查詢
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
// "A",MatchMode.START 以A開頭的
criteria.add(Restrictions.like("name", "A", MatchMode.START));
// 上下兩種方法都可行
// criteria.add(Restrictions.like("name", "A%"));
List<Street> list = criteria.list();
for (Street street : list) {
System.out.println(street);
}
session.close();
排序查詢
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
criteria.addOrder(Order.desc("id"));
List<Street> list = criteria.list();
for (Street street : list) {
System.out.println(street);
}
session.close();
動態(tài)查詢
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
Street street = new Street();
street.setId(2);
if (street.getId() != 0) {
criteria.add(Restrictions.eq("id", street.getId()));
}
if (street.getName() != null) {
criteria.add(Restrictions.eq("name", street.getName()));
}
List<Street> list = criteria.list();
for (Street street1 : list) {
System.out.println(street1);
}
session.close();
投影查詢
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
criteria.setProjection(Projections.projectionList()
.add(Property.forName("id"))
.add(Property.forName("name")));
List<Object[]> list = criteria.list();
for (Object[] objects : list) {
System.out.println(Arrays.toString(objects));
}
session.close();
查詢記錄條數(shù)
Session session = HibernateUtil.getSession();
Criteria criteria = session.createCriteria(Street.class);
criteria.setProjection(Projections.rowCount());
Long count = (Long) criteria.uniqueResult();
System.out.println(count);
session.close();
離線查詢
//不通過session創(chuàng)建criteria
DetachedCriteria detachedCriteria=DetachedCriteria.forClass(User.class);
detachedCriteria.add(Restrictions.eq("id", 1));
Session session = HibernateUtil.getSession();
//當要用到時 傳session進去 session關(guān)閉 不影響上面創(chuàng)建的datechedCriteria 要用時重新創(chuàng)建一個新的session傳進去
Criteria criteria = detachedCriteria.getExecutableCriteria(session);
List<User> list = criteria.list();
for (User user : list) {
System.out.println(user);
}
session.close();
使用SQLQuery接口 Sql
原生的sql語句 簡單介紹 不常用
Session session = HibernateUtil.getSession();
String sql="select * from user";
SQLQuery sqlQuery = session.createSQLQuery(sql);
//設置實體類對象 這樣查詢出來是User對象 不然是Object數(shù)組 (投影查詢)
sqlQuery.addEntity(User.class);
List<User> list = sqlQuery.list();
for (User user : list) {
System.out.println(user);
}
session.close();
命名方法查詢
在映射文件中配置 寫在class標簽外面
<query name="selectAll">
from Street
</query>
Session session = HibernateUtil.getSession();
Query query = session.getNamedQuery("selectAll");
List<Street> list = query.list();
for (Street street : list) {
System.out.println(street);
}
session.close();
對象導航查詢OID get load方法
get(實體類.class,主鍵);
一執(zhí)行馬上發(fā)生sql語句查詢
load(實體類.class,主鍵);
延遲查詢 執(zhí)行后不馬上去查詢 當有用到查詢結(jié)果時才發(fā)生sql語句去查詢