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

最新文章

  1. mysql关于or的索引问题
  2. Hybris电商方案介绍(企业全渠道) B2B B2C O2O建设
  3. parse,tryparse区别
  4. C# 格式化字符串(转载)
  5. Qt之再谈窗体阴影
  6. HDU 1787 GCD Again
  7. RAC优化大框架的分配(jumbo frame)
  8. 队列详解及java实现
  9. JavaScript 浏览器类型及版本号
  10. 关于支付时rsa加密解密的函数
  11. 试着简单易懂记录synchronized this object Class的区别,模拟ConcurrentHashMap
  12. 20165223《信息安全系统设计基础》第九周学习总结 &amp; 第八周课上测试
  13. 网页头部meta标签
  14. java ----&gt; 注解/反射
  15. java利用Comparator接口对自定义数组排序
  16. 将目录下面所有的 .cs 文件合并到一个 code.cs 文件中,写著作权复制代码时的必备良药
  17. centos上自动执行脚本执行php文件
  18. linux源码安装 rpm命令
  19. Linux下配置Samba服务器全过程
  20. Good Bye 2017 部分题解

热门文章

  1. 踩坑--http返回码之302状态码
  2. 修改OPENSUSE 桌面快速搜索快捷键
  3. Coursera 机器学习 第9章(上) Anomaly Detection 学习笔记
  4. 【卷土重来之C#学习笔记】(三) 类的基本概念
  5. 获取top10
  6. 初学Hadoop之WordCount词频统计
  7. sqlServer游标的使用
  8. Oracle中scott用户下基本表练习SQL语句
  9. C# ObjectArx cad二次开发
  10. 集合之Iterator迭代器