QBC(query by criteria) demo

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


import java.util.List;

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

import com.gyf.hibernate.domain.User;

/**
 * Criteria 对象学习
 *    QBC(query by criteria),hibernate提供纯面向对象查询语言,
 *    提供直接使用PO对象进行操作
 */
public class Lesson10 {

    @Test
    public void test1(){
        //用户数据
        //1.获取核心 配置文件对象
        Configuration cfg = new Configuration().configure();
        
        //2.创建会话工厂
        SessionFactory factory = cfg.buildSessionFactory();
        
        //3.通过会话工厂获取session对象
        Session session =  factory.openSession();
    
        //创建Criteria查询对象
        Criteria criteria = session.createCriteria(User.class);
        
        //加条件gyf,123
        //eq =
//        criteria.add(Restrictions.eq("username", "gyf"));
//        criteria.add(Restrictions.eq("password", "123"));
//        System.out.println(criteria.uniqueResult());
        
        // 【gt 大于>】【 ge大于等于>=】
        //criteria.add(Restrictions.ge("uid", 10));
        // 【lt 小于>】【 le小于等于>=】
        
        // 【模糊查询】
        //criteria.add(Restrictions.like("username", "%y%"));
        
        System.out.println(criteria.list());
        
        //4.关闭会话
        session.close();
        
        //5.关闭工厂,释放资源
        factory.close();
    }
    
}
复制代码

 

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