HQL demo

复制代码
package com.gyf.hibernate.test;


import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test;

import com.gyf.hibernate.domain.User;

/**
 * Query对象学习
 * @author gyf
 *
 */
public class Lesson09 {

    @Test
    public void test1(){
        //用户数据
        //1.获取核心 配置文件对象
        Configuration cfg = new Configuration().configure();
        
        //2.创建会话工厂
        SessionFactory factory = cfg.buildSessionFactory();
        
        //3.通过会话工厂获取session对象
        Session session =  factory.openSession();
    
        //创建查询对象
        //sql:select * from t_user where username='gyf' and password = '123';
        //hql:面向对象的查询语言
        Query query = session.createQuery("from User where username=? and password=?");
        query.setParameter(0, "gyf");
        query.setParameter(1, "123");
        
        //执行查询
        User user = (User) query.uniqueResult();
        System.out.println(user);
        
        //4.关闭会话
        session.close();
        
        //5.关闭工厂,释放资源
        factory.close();
    }
    
    @Test
    public void test2(){
        //用户数据
        //1.获取核心 配置文件对象
        Configuration cfg = new Configuration().configure();
        
        //2.创建会话工厂
        SessionFactory factory = cfg.buildSessionFactory();
        
        //3.通过会话工厂获取session对象
        Session session =  factory.openSession();
    
        //查询对象
        Query query = session.createQuery("from User");
        
        //分页查询 limit?,? 【limit 3,3】
        query.setFirstResult(3);//启始位置
        query.setMaxResults(3);//返回的数据条数
        
        //返回多行数据
        List<User> list = query.list();
        for(User obj : list){
            System.out.println(obj);
        }
        
        //query.list() 返回多行数据
        //query.uniqueResult 返回一行数据
        
        
        //4.关闭会话
        session.close();
        
        //5.关闭工厂,释放资源
        factory.close();
    }
}
复制代码

 

posted @   expworld  阅读(78)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示