hibernate框架學習筆記7:HQL查詢、Criteria查詢

来源:https://www.cnblogs.com/xuyiqing/archive/2018/02/18/8452954.html
-Advertisement-
Play Games

HQL查詢:hibernate獨有的查詢語言 適用於不複雜的多表查詢 示例: 實體類: package domain; public class Customer { private Long cust_id; private String cust_name; private String cus ...


HQL查詢:hibernate獨有的查詢語言

適用於不複雜的多表查詢

示例:

實體類:

package domain;

public class Customer {
    
    private Long cust_id;
    private String cust_name;
    private String cust_source;
    private String cust_industry;
    private String cust_level;
    private String cust_linkman;
    private String cust_phone;
    private String cust_mobile;
    public Long getCust_id() {
        return cust_id;
    }
    public void setCust_id(Long cust_id) {
        this.cust_id = cust_id;
    }
    public String getCust_name() {
        return cust_name;
    }
    public void setCust_name(String cust_name) {
        this.cust_name = cust_name;
    }
    public String getCust_source() {
        return cust_source;
    }
    public void setCust_source(String cust_source) {
        this.cust_source = cust_source;
    }
    public String getCust_industry() {
        return cust_industry;
    }
    public void setCust_industry(String cust_industry) {
        this.cust_industry = cust_industry;
    }
    public String getCust_level() {
        return cust_level;
    }
    public void setCust_level(String cust_level) {
        this.cust_level = cust_level;
    }
    public String getCust_linkman() {
        return cust_linkman;
    }
    public void setCust_linkman(String cust_linkman) {
        this.cust_linkman = cust_linkman;
    }
    public String getCust_phone() {
        return cust_phone;
    }
    public void setCust_phone(String cust_phone) {
        this.cust_phone = cust_phone;
    }
    public String getCust_mobile() {
        return cust_mobile;
    }
    public void setCust_mobile(String cust_mobile) {
        this.cust_mobile = cust_mobile;
    }
    @Override
    public String toString() {
        return "Customer [cust_id=" + cust_id + ", cust_name=" + cust_name + "]";
    }
}
View Code

自定義工具類:

package utils;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtils {
    private static SessionFactory sf;
    
    static{
        //1 創建,調用空參構造
        Configuration conf = new Configuration().configure();
        //2 根據配置信息,創建 SessionFactory對象
         sf = conf.buildSessionFactory();
    }
    
    //獲得session => 獲得全新session
    public static Session openSession(){
                //3 獲得session
                Session session = sf.openSession();
                
                return session;
        
    }
    //獲得session => 獲得與線程綁定的session
    public static Session getCurrentSession(){
        //3 獲得session
        Session session = sf.getCurrentSession();
        
        return session;
    }    
}
View Code

測試類:

package hql;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test;

import domain.Customer;
import utils.HibernateUtils;

//測試HQL語句
public class Demo {

    @Test
    //基本查詢
    public void fun1(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1> 書寫HQL語句
        //String hql = " from domain.Customer ";
        String hql = " from Customer "; // 如果查詢所有Customer對象,可省略全名
        //2> 根據HQL語句創建查詢對象
        Query query = session.createQuery(hql);
        //3> 根據查詢對象獲得查詢結果
        List<Customer> list = query.list();    // 返回list結果
        //query.uniqueResult();//接收唯一的查詢結果
        
        System.out.println(list);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
    }
    
    @Test
    //條件查詢
    //HQL語句中,不可能出現任何資料庫相關的信息的
    //不會出現資料庫的表名類名欄位名,使用的是實體類的屬性名
    public void fun2(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1> 書寫HQL語句
        String hql = " from Customer where cust_id = 1 "; // 查詢所有Customer對象
        //2> 根據HQL語句創建查詢對象
        Query query = session.createQuery(hql);
        //3> 根據查詢對象獲得查詢結果
        Customer c = (Customer) query.uniqueResult();
        
        System.out.println(c);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //條件查詢
    //問號占位符
    public void fun3(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1> 書寫HQL語句
        String hql = " from Customer where cust_id = ? "; // 查詢所有Customer對象
        //2> 根據HQL語句創建查詢對象
        Query query = session.createQuery(hql);
        //設置參數
        //query.setLong(0, 1l);
        query.setParameter(0, 1l);
        //3> 根據查詢對象獲得查詢結果
        Customer c = (Customer) query.uniqueResult();
        
        System.out.println(c);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //條件查詢
    //命名占位符
    public void fun4(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1> 書寫HQL語句
        String hql = " from Customer where cust_id = :cust_id "; // 查詢所有Customer對象
        //2> 根據HQL語句創建查詢對象
        Query query = session.createQuery(hql);
        //設置參數
        query.setParameter("cust_id", 1l);
        //3> 根據查詢對象獲得查詢結果
        Customer c = (Customer) query.uniqueResult();
        
        System.out.println(c);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //分頁查詢
    public void fun5(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1> 書寫HQL語句
        String hql = " from Customer  "; // 查詢所有Customer對象
        //2> 根據HQL語句創建查詢對象
        Query query = session.createQuery(hql);
        //設置分頁信息 limit ?,?
        query.setFirstResult(0);
        query.setMaxResults(1);
        //3> 根據查詢對象獲得查詢結果
        List<Customer> list =  query.list();
        
        System.out.println(list);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
}

 

Criteria查詢:

hibernate獨創的,無語句面向對象查詢

適用於單表查詢

示例:

package criteria;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.junit.Test;

import domain.Customer;
import utils.HibernateUtils;

//測試Criteria查詢
public class Demo {

    @Test
    //基本查詢
    public void fun1(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        
        //查詢所有的Customer對象
        Criteria criteria = session.createCriteria(Customer.class);
        
        List<Customer> list = criteria.list();
        
        System.out.println(list);
        
//        Customer c = (Customer) criteria.uniqueResult();
        
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //條件查詢
    //HQL語句中,不可能出現任何資料庫相關的信息的
    // >                 gt
    // >=                ge
    // <                lt
    // <=                le
    // ==                eq
    // !=                ne
    // in                in
    // between and        between
    // like             like
    // is not null         isNotNull
    // is null            isNull
    // or                or
    // and                and
    public void fun2(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //創建criteria查詢對象
        Criteria criteria = session.createCriteria(Customer.class);
        //添加查詢參數 => 查詢cust_id為1的Customer對象
        criteria.add(Restrictions.gt("cust_id", 1l));
        //執行查詢獲得結果
        Customer c = (Customer) criteria.uniqueResult();
        System.out.println(c);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    
    
    @Test
    //分頁查詢
    public void fun3(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //創建criteria查詢對象
        Criteria criteria = session.createCriteria(Customer.class);
        //設置分頁信息 limit ?,?
        criteria.setFirstResult(1);
        criteria.setMaxResults(2);
        //執行查詢
        List<Customer> list = criteria.list();
        
        System.out.println(list);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //查詢總記錄數
    public void fun4(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //創建criteria查詢對象
        Criteria criteria = session.createCriteria(Customer.class);
        //設置查詢的聚合函數 => 總行數
        criteria.setProjection(Projections.rowCount());
        //執行查詢
        Long count = (Long) criteria.uniqueResult();
        
        System.out.println(count);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
}

 

 

原生SQL查詢:

適用於相當複雜的業務

package sql;

import java.util.Arrays;
import java.util.List;

import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test;

import domain.Customer;
import utils.HibernateUtils;

//測試原生SQL查詢
public class Demo {

    @Test
    //基本查詢
    public void fun1(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1 書寫sql語句
        String sql = "select * from cst_customer";
        
        //2 創建sql查詢對象
        SQLQuery query = session.createSQLQuery(sql);
        
        //3 調用方法查詢結果
        List<Object[]> list = query.list();
        //query.uniqueResult();
        
        for(Object[] objs : list){
            System.out.println(Arrays.toString(objs));
        }
        
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //基本查詢
    public void fun2(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1 書寫sql語句
        String sql = "select * from cst_customer";
        
        //2 創建sql查詢對象
        SQLQuery query = session.createSQLQuery(sql);
        //指定將結果集封裝到哪個對象中
        query.addEntity(Customer.class);
        
        //3 調用方法查詢結果
        List<Customer> list = query.list();
        
        System.out.println(list);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //條件查詢
    public void fun3(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1 書寫sql語句
        String sql = "select * from cst_customer where cust_id = ? ";
        
        //2 創建sql查詢對象
        SQLQuery query = session.createSQLQuery(sql);
        
        query.setParameter(0, 1l);
        //指定將結果集封裝到哪個對象中
        query.addEntity(Customer.class);
        
        //3 調用方法查詢結果
        List<Customer> list = query.list();
        
        System.out.println(list);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
    
    @Test
    //分頁查詢
    public void fun4(){
        //1 獲得session
        Session session = HibernateUtils.openSession();
        //2 控制事務
        Transaction tx = session.beginTransaction();
        //3執行操作
        //-------------------------------------------
        //1 書寫sql語句
        String sql = "select * from cst_customer  limit ?,? ";
        
        //2 創建sql查詢對象
        SQLQuery query = session.createSQLQuery(sql);
        
        query.setParameter(0, 0);
        query.setParameter(1, 1);
        //指定將結果集封裝到哪個對象中
        query.addEntity(Customer.class);
        
        //3 調用方法查詢結果
        List<Customer> list = query.list();
        
        System.out.println(list);
        //-------------------------------------------
        //4提交事務.關閉資源
        tx.commit();
        session.close();
        
        
    }
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • https://www.patest.cn/contests/pat-b-practise/1038 ...
  • 1、List和Set介面繼承自Collection介面,而Map不是繼承的Collection介面 2.、List介面 List介面有三個實現類:LinkedList,ArrayList,Vector LinkedList:底層基於鏈表實現,鏈表記憶體是散亂的,每一個元素存儲本身記憶體地址的同時還存儲下 ...
  • 兩個實體類:客戶與聯繫人,一個客戶可以有多個聯繫人 客戶類: package domain; import java.util.HashSet; import java.util.Set; //客戶實體 public class Customer { private Long cust_id; pr ...
  • 我們以 printf 這個 very 熟悉的函數為例,來分析一下變參函數。先看下 printf 函數的定義: ~~~~ int printf(const char fmt, ...) { int i; int len; / va_list 即 char / va_list args; va_star ...
  • 2、xml配置文件: 3、實例對象: 4、BeanFactory工廠: ...
  • Python urllib urlretrieve函數解析 利用urllib.request.urlretrieve函數下載文件 覺得有用的話,歡迎一起討論相互學習~ "Follow Me" 參考文獻 "Urlretrieve函數解析" urllib.request.urlretrieve函數解析 ...
  • 一、攔截器 1.概述 ​ 在struts2中,攔截器(Interceptor)是用來動態攔截Action執行的對象。 ​ 攔截器有點類似以前Servlet階段的Filter(過濾器) , 能夠在請求到達Action之前進行攔截操作, 可以在裡面進行判斷校驗。 典型的例子: 登錄攔截. 註:過濾器可以 ...
  • 拖了這麼久,最終還是戰勝了懶惰,打開電腦寫了這篇博客,內容也很簡單,python實現字元串轉整型的int方法 python已經實現了int方法,我們為什麼還要再寫一遍,直接用不就好了?事實確實如此,但是int函數看似簡單,實際上自己來實現還是有一些坑的 1.判斷正負 這點很容易忘記 2.python ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...