2018.11.13 Hibernate 中数据库查询中的Criteria查询实例

Criteria是面向对象的无语句查询

Demo.java

package com.legend.b_criteria;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.junit.jupiter.api.Test;

import com.legend.domain.Customer;
import com.legend.utils.HibernateUtils;

/**
 * 学习Criteria语法
 * @author qichunlin
 *
 */
public class Demo {
    //基本语法
    @Test
    public void fun1() {
        Session session = HibernateUtils.openSession();
        Transaction tx = session.beginTransaction();
        //--------------
        Criteria criteria = session.createCriteria(Customer.class);

        List<Customer> list = criteria.list();
        System.out.println(list);
        //--------------

        tx.commit();
        session.close();

    }

    //条件查询
    @Test
    public void fun2(){
        //
        Session session = HibernateUtils.openSession();
        Transaction tx = session.beginTransaction();
        //--------------
        //创建Criteria 对象
        Criteria criteria = session.createCriteria(Customer.class);

        //添加Criteria的查询参数
        criteria.add(Restrictions.eq("cust_id", 1l));

        //获取查询的结果
        Customer c = (Customer) criteria.uniqueResult();
        System.out.println(c);
        //--------------

        //事务的提交
        tx.commit();
        session.close();

    }

    //分页查询
    //(当前页数-1)*每页条数
    @Test
    public void fun3() {
        //
        Session session = HibernateUtils.openSession();
        Transaction tx = session.beginTransaction();
        //--------------
        //编写HQL语句
        Criteria criteria = session.createCriteria(Customer.class);

        criteria.setFirstResult(1);
        criteria.setMaxResults(2);

        List<Customer> list = criteria.list();
        System.out.println(list);
        //--------------

        tx.commit();
        session.close();

    }

    //排序检索
    @Test
    public void fun5() {
        //
        Session session = HibernateUtils.openSession();
        Transaction tx = session.beginTransaction();
        //--------------
        Criteria criteria = session.createCriteria(Customer.class);

        criteria.addOrder(Order.desc("cust_id"));

        List<Customer> list = criteria.list();
        System.out.println(list);
        //--------------

        tx.commit();
        session.close();

    }

    //统计查询
    @Test
    public void fun6() {
        //
        Session session = HibernateUtils.openSession();
        Transaction tx = session.beginTransaction();
        //--------------
        //编写HQL语句
        Criteria criteria = session.createCriteria(Customer.class);

        //设置查询目标
        criteria.setProjection(Projections.rowCount());
        //List list = query.list();
        List<Long> list = criteria.list();
        System.out.println(list);
        //--------------

        tx.commit();
        session.close();

    }
}

基本查询

统计查询

附上hibernate的额核心配置文件xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<!-- 配置参数文件 -->
<hibernate-configuration>
    <session-factory>
        <!--
            #hibernate.dialect org.hibernate.dialect.MySQLDialect
            #hibernate.dialect org.hibernate.dialect.MySQLInnoDBDialect
            #hibernate.dialect org.hibernate.dialect.MySQLMyISAMDialect
            #hibernate.connection.driver_class com.mysql.jdbc.Driver
            #hibernate.connection.url jdbc:mysql:///test
            #hibernate.connection.username gavin
            #hibernate.connection.password
            配置mysql相关参数
         -->
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql:///crm</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">123456</property>

        <!-- 配置mysql方言 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

        <!--
            sql语句显示
            #hibernate.show_sql true
            # format SQL in log and console
            #hibernate.format_sql true

         -->
        <property name="hibernate.format_sql">true</property>
        <property name="hibernate.show_sql">true</property>

        <!--
            ## auto schema export
            #hibernate.hbm2ddl.auto create-drop
            #hibernate.hbm2ddl.auto create
            #hibernate.hbm2ddl.auto update
            #hibernate.hbm2ddl.auto validate
         -->
        <property name="hibernate.hbm2ddl.auto">update</property>

        <!--
            设置数据库隔离级别
            ## specify a JDBC isolation level
            #hibernate.connection.isolation 4
         -->
         <property name="hibernate.connection.isolation">4</property>

        <!-- 指定session与当前线程绑定 -->
        <property name="hibernate.current_session_context_class">thread</property>

        <!-- 配置映射文件加载 orm元数据 -->
        <mapping resource="com/legend/domain/Customer.hbm.xml"/>
        <mapping resource="com/legend/domain/LinkMan.hbm.xml" />
        <mapping resource="com/legend/domain/User.hbm.xml" />
        <mapping resource="com/legend/domain/Role.hbm.xml" />

    </session-factory>
</hibernate-configuration>  

传统的Criteria

离线的Criteria

原文地址:https://www.cnblogs.com/qichunlin/p/9948337.html

时间: 2024-11-06 14:26:58

2018.11.13 Hibernate 中数据库查询中的Criteria查询实例的相关文章

2018.11.4 Hibernate中多对多的关系

简单总结一下 多表关系 一对多/多对一 O 对象 一的一方使用集合. 多的一方直接引用一的一方. R 关系型数据库 多的一方使用外键引用一的一方主键. M 映射文件 一: 多: 操作: 操作管理级别属性. cascade: 级联操作 减少我们书写的操作代码. none(默认值) 不级联 save-update: 级联保存 delete: 级联删除 all: 级联保存+级联删除 结论: 可以使用save-update.不推荐使用delete. 也可以不用cascade. inverse: 反转关系

2018/11/13 23:17:25

螺纹钢继续找机会做空,目前走势还是空头主导,越接近4000附近的卖点越应该入场: 郑棉回踩M30中枢中轨受阻回落,继续做空为主: 郑醇,果然再次盘整出更大级别震荡,可惜一念之差没补回空单..新低可期 原文地址:https://www.cnblogs.com/taoeternal/p/db4ddde61658ab1734a6c34db1e0b5da.html

hibernate里的generator中class =value介绍

在*.hbm.xml必须声明的<generator>子元素是一个Java类的名字,用来为该持久化类的实例生成唯一的标识.<generator class="sequence"/>这是一个非常简单的接口:某些应用程序可以选择提供他们自己特定的实现.当然,Hibernate提供了很多内置的实现.下面是一些内置生成器的快捷名字:increment(递增)    用于为long, short或者int类型生成唯一标识.只有在没有其他进程往同一张表中插入数据时才能使用.

JPA criteria 查询:类型安全与面向对象

参考:https://my.oschina.net/zhaoqian/blog/133500 一.JPA元模型概念,及使用 在JPA中,标准查询是以元模型的概念为基础的.元模型是为具体持久化单元的受管实体定义的.这些实体可以是实体类,嵌入类或者映射的父类.提供受管实体元信息的类就是元模型类. 描述受管类的状态和他们之间的关系的静态元模型类可以 1.从注解处理器产生 2.从程序产生 3.用EntityManager访问. 如下code,一个简单的实体类package com.demo.entiti

数据库设计中的13个技巧

1.原始单据与实体之间的关系可以是一对一.一对多.多对多的关系.在一般情况下,它们是一对一的关系:即一张原始单据对应且只对应一个实体.在特殊情况下,它们可能是一对多或多对一的关系,即一张原始单证对应多个实体,或多张原始单证对应一个实体.这里的实体可以理解为基本表.明确这种对应关系后,对我们设计录入界面大有好处. [例1]:一份员工履历资料,在人力资源信息系统中,就对应三个基本表:员工基本情况表.社会关系表.工作简历表.这就是"一张原始单证对应多个实体"的典型例子. 2.主键与外键一般而

Atitit.Hibernate中Criteria 使用总结and 关联查询 and 按照子对象查询 o9o

Atitit.Hibernate中Criteria 使用总结and 关联查询 and 按照子对象查询 o9o 1. Criteria,,Criterion ,, 1 <2. 主要的对象黑头配置磊个关联,三 1 3. Criteria 黑头配置关联查询了... 2 4. Ati Meata 配置关联 @CriteriaRelt 2 5. 关联createCriteria() 3 6. Criteria的使用outline 4 7. 参考:: 5 1. Criteria,,Criterion ,,

Hibernate之查询中get()和load()的区别,list()和iterate()的区别

[Hibernate]之查询中get()和load()的区别,list()和iterate()的区别 list()查询 //一次性把数据对象取出来 @Test public void findTestList(){ Session s=sessionFactory.getCurrentSession(); s.beginTransaction(); List<Person> persons=s.createQuery("from Person").list(); for(P

JAVAEE——宜立方商城13:Mycat数据库分片、主从复制、读写分离、100%Linux中成功安装Mysql的方法

1 海量数据的存储问题 如今随着互联网的发展,数据的量级也是撑指数的增长,从GB到TB到PB.对数据的各种操作也是愈加的困难,传统的关系性数据库已经无法满足快速查询与插入数据的需求.这个时候NoSQL的出现暂时解决了这一危机.它通过降低数据的安全性,减少对事务的支持,减少对复杂查询的支持,来获取性能上的提升. 但是,在有些场合NoSQL一些折衷是无法满足使用场景的,就比如有些使用场景是绝对要有事务与安全指标的.这个时候NoSQL肯定是无法满足的,所以还是需要使用关系性数据库.如果使用关系型数据库

在数据库查询中不走索引的情况与压力测试

重点关注: 1) 没有查询条件,或者查询条件没有建立索引 例如: select * from tab; 全表扫描. select * from tab where 1=1; 在业务数据库中,特别是数据量比较大的表.是没有全表扫描这种需求. 1.对用户查看是非常痛苦的. 2.对服务器来讲毁灭性的. 例如: select * from tab; SQL改写成以下语句: selec * from tab order by price limit 10 需要在price列上建立索引 select * f