hibernate最新文档

项目仓库地址项目201102-hibernateSelect

数据准备

-- 创建数据表
drop table if exists t_book;
create table t_book(
id int(11) primary key auto_increment,
name varchar(100) comment '名称',
author varchar(50) comment '作者',
publish_date datetime comment '出版日期',
price decimal(10, 2) comment '价格',
catalog_id int(11) comment '分类id'
) comment '书籍表'; drop table if exists t_book_catalog;
create table t_book_catalog(
id int(11) primary key auto_increment,
name varchar(100) comment '名称'
) comment '书籍分类表'; -- 插入数据
insert into t_book_catalog(name) values
('经典'), ('心理'), ('科幻'); insert into t_book(name, author, publish_date, price, catalog_id) values
('三体', '刘慈欣', '2009-11-23', 19.3, 3),
('流浪地球', '刘慈欣', '2007-01-08', 15, 3),
('西游记', '吴承恩', '1630-01-13', 5, 1),
('象与骑象人', '乔纳森·海特', '2012-7-4', 39.9, 2),
('社会性动物', '艾略特·阿伦森', '1960-5-4', 32.9, 2);

实体类Book

@Entity
@Table(name = "t_book", schema = "test", catalog = "")
public class Book {
@Id
@Column(name = "id")
private int id; @Basic
@Column(name = "name")
private String name; @Basic
@Column(name = "author")
private String author; @Basic
@Column(name = "publish_date")
private Timestamp publishDate; @Basic
@Column(name = "price")
private BigDecimal price; @Transient
private Integer catalogId; @ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "catalog_id", referencedColumnName = "id")
private BookCatalog bookCatalog; ...
}

实体类BookCatalog:

@Entity
@Table(name = "t_book_catalog", schema = "test", catalog = "")
public class BookCatalog {
@Id
@Column(name = "id")
private int id; @Basic
@Column(name = "name")
private String name; @OneToMany(mappedBy = "bookCatalog", fetch = FetchType.EAGER)
private List<Book> bookList; ...
}

Query 和 Criteria 对比

HQL是 Hibernate Query Language 的缩写。

HQL SQL
目标 面向对象 面向数据库表
基本格式 from + 类名 + 别名 + where + 对象的属性 from + 表名 + where + 表中字段
是否区分大小写 是,关键字不区分
下标 下标从0开始(hibernate5后不再支持占位符) 下标从1开始
是否支持:命名参数 支持 不支持

Query使用

  1. 单对象返回单字段

    String hql = "SELECT b.name as bookName FROM Book b";
    Query query = this.session.createQuery(hql);
    List<String> bookNameList = query.list();
  2. 单对象返回多字段

    String hql = "SELECT b.id, b.name as bookName FROM Book b";
    Query query = this.session.createQuery(hql);
    List<Object[]> bookInfoList = query.list();
  3. 单对象返回多字段,多字段构建返回对象

    // 必须存在 public Book(Integer id, String name) 这样的构造函数
    String hql = "SELECT new Book(b.id, b.name) FROM Book b";
    Query query = session.createQuery(hql);
    List<Book> bookList = query.list();
  4. 单对象返回对象

    String hql = "FROM Book b";
    Query query = session.createQuery(hql);
    List<Book> bookList = query.list();
  5. 单对象返回多字段,多字段构建Map

    String hql = "SELECT new Map(b.id,b.name) FROM Book b";
    Query query = session.createQuery(hql);
    List<Map> list = query.list();
    for (Map b : list) {
    System.out.println(b.toString());
    }

    输出结果:

    {0=1, 1=三体}
    {0=2, 1=流浪地球}
    {0=3, 1=西游记}
    {0=4, 1=象与骑象人}
    {0=5, 1=社会性动物}
  6. 命名参数

    // 1. 基础类型
    String hql = "FROM Book WHERE id = :bookId";
    Query query = session.createQuery(hql);
    query.setParameter("bookId", 1);
    Book b = (Book) query.getSingleResult(); // 2. 数组
    String hql = "FROM Book WHERE id IN (:bookIds)";
    Query query = session.createQuery(hql);
    query.setParameterList("bookIds", new Integer[]{1, 3, 5});
    List<Book> bookList = query.list();
    // 3. 列表
    String hql = "FROM Book WHERE id IN (:bookIds)";
    Query query = session.createQuery(hql);
    List<Integer> bookIdList = new ArrayList<>();
    bookIdList.add(1);
    bookIdList.add(3);
    bookIdList.add(5);
    query.setParameterList("bookIds", bookIdList);
    List<Book> bookList = query.list();

    query#getSingleResult() 和 query#uniqueResult() 的区别:

    两者都返回一条结果;不同的是,在查询结果为空时前者抛出异常,后者则返回null

  7. 连接查询

    // 注意:连接查询中的 bookCatalog 是关联对象
    String hql1 = "SELECT b.id, b.name, bc.name as catalog_name FROM Book b JOIN BookCatalog bc ON bc.id=b.bookCatalog";
    String hql2 = "SELECT b.id, b.name, bc.name as catalog_name FROM Book b, BookCatalog bc WHERE bc.id=b.bookCatalog";
    Query query = session.createQuery(hql2);
    List<Object[]> bookInfoList = query.list();
  8. 聚合函数

    String hql = "SELECT COUNT(*) FROM Book";
    Query query = session.createQuery(hql);
    Long count = (Long) query.getSingleResult();

    还有其他聚合函数 sum、avg、max、min、count

  9. 分页

    // 页码从1开始
    int pageNo = 3;
    int pageSize = 2;
    //结果集第一条记录,从0开始
    int offset = (pageNo-1) * pageSize; String hql = "FROM Book";
    Query query = session.createQuery(hql);
    query.setFirstResult(offset);
    query.setMaxResults(pageSize);
    List<Book> bookList = query.list();
  10. 排序

    String hql = "FROM Book ORDER BY price DESC";
    Query query = session.createQuery(hql);
    List<Book> bookList = query.list();
  11. session.createSqlQuery

    String sql = "SELECT name FROM t_book";
    Query query = this.session.createSQLQuery(sql);
    List<String> list = query.list(); String sql = "SELECT * FROM t_book";
    Query query = this.session.createSQLQuery(sql);
    List<Object[]> list = query.list();

    **createSqlQuery(sql) 的返回值类型 和 createQuery(hql) 的是相同的,所以Query的方法也能用。比如:分页、命名参数 **

    String sql = "SELECT book.* FROM t_book book WHERE book.price>:price";
    Query query = this.session.createSQLQuery(sql);
    query.setParameter("price", "10");
    query.setFirstResult(0);
    query.setMaxResults(2);
    List<Object[]> bookInfoList = query.list();

Criteria使用

Hibernate5.2之后,Criteria标准化查询差不多都转到使用JPA包了,因此像session.createCriteria()等方法都提示了已过时。Hibernate5.2文档** Criteria 5.2前后API和使用

参考: https://www.cnblogs.com/lukelook/p/9692429.html

QBC:Query By Criteria

Criteria是一种比HQL更面向对象的查询方式

  1. 最简单的例子:

    Criteria criteria = session.createCriteria(Book.class);
    List<Book> bookList = criteria.list();

    主要类:

    • Criteria
    • Criterion 规则
    • Order 排序
    • Restrictions 条件
  2. 比较运算符:

    Criteria criteria = this.session.createCriteria(Book.class);
    //Criterion criterion = Restrictions.eq("id", 3);
    //criteria.add(criterion);
    criteria.add(Restrictions.gt("price", new BigDecimal(30)));
    List<Book> bookList = criteria.list();

    更多运算符:

    SQL运算符 Restrictions 方法 说明
    = Restrictions.eq() 等于
    <> Restrictions.not(Exprission.eq()) 不等于
    > Restrictions.gt() 大于
    >= Restrictions.ge() 大于等于
    < Restrictions.lt() 小于
    <= Restrictions.le() 小于等于
    is null Restrictions.isnull() 等于空值
    is not null Restrictions.isNotNull() 非空值
    like Restrictions.like() 字符串模式匹配
    and Restrictions.and() 逻辑与
    and Restrictions.conjunction() 逻辑与
    or Restrictions.or() 逻辑或
    or Restrictions.disjunction() 逻辑或
    not Restrictions.not() 逻辑非
    in(列表) Restrictions.in() 等于列表中的某一个值
    ont in(列表) Restrictions.not(Restrictions.in()) 不等于列表中任意一个值
    between x and y Restrictions.between() 闭区间xy中的任意值
    not between x and y Restrictions.not(Restrictions..between()) 小于值X或者大于值y
  3. and 和 or 逻辑

    Criteria criteria = this.session.createCriteria(Book.class);
    Date minDate = new SimpleDateFormat("yyyy-MM-dd").parse("2008-10-23");
    Criterion gtPublishDateCr = Restrictions.gt("publishDate", minDate);
    Criterion eqAuthorCr = Restrictions.eq("author", "刘慈欣");
    LogicalExpression andExp = Restrictions.and(gtPublishDateCr, eqAuthorCr);
    criteria.add(andExp);
    List<Book> bookList = criteria.list();
  4. 直接使用SQL

    Criteria criteria = this.session.createCriteria(Book.class);
    Criterion gtPriceCr = Restrictions.sqlRestriction("{alias}.price > ?", new BigDecimal(20), StandardBasicTypes.BIG_DECIMAL);
    criteria.add(gtPriceCr);
    List<Book> bookList = criteria.list();

    {alias} 表示类的别名

  5. 分页

    // 页码从1开始
    int pageNo = 1;
    int pageSize = 2;
    //结果集第一条记录,从0开始
    int offset = (pageNo-1) * pageSize;
    Criteria cr = session.createCriteria(Book.class);
    cr.setFirstResult(offset);
    cr.setMaxResults(pageSize);
    List<Book> bookList = cr.list();
  6. 排序

    Criteria cr = session.createCriteria(Book.class);
    cr.add(Restrictions.like("author", "刘慈欣"));
    cr.addOrder(Order.asc("publishDate"));
    List<Book> bookList = cr.list();
  7. 聚合函数

    Criteria cr = session.createCriteria(Book.class);
    //cr.setProjection(Projections.rowCount());
    //cr.setProjection(Projections.sum("price"));
    //cr.setProjection(Projections.countDistinct("author"));
    //cr.setProjection(Projections.max("price"));
    //cr.setProjection(Projections.min("price"));
    cr.setProjection(Projections.avg("price"));
    Double avgPrice = (Double) cr.uniqueResult();

    注意返回类型

  8. 连接查询

    // 查询心理类的、出版时间大于2010年的书籍
    Criteria cr = session.createCriteria(Book.class);
    Date gtDate = new SimpleDateFormat("yyyy-MM-dd").parse("2010-01-01");
    cr.add(Restrictions.gt("publishDate", gtDate));
    cr.createCriteria("bookCatalog")
    .add(Restrictions.eq("name", "心理"));
    List<Book> bookList = cr.list();

    使用createAlias()

    Date gtDate = new SimpleDateFormat("yyyy-MM-dd").parse("2010-01-01");
    //查询心理类的、出版时间大于2010年的书籍
    Criteria cr = session.createCriteria(Book.class, "b");
    cr.createAlias("bookCatalog", "bc");
    cr.add(Restrictions.gt("b.publishDate", gtDate));
    cr.add(Restrictions.eq("bc.name", "心理"));
    List<Book> bookList = cr.list();
    for (Book b : bookList) {
    System.out.println(b.toString());
    }

    设置关联对象的加载策略

    //查询心理的书籍分类
    Criteria cr = session.createCriteria(BookCatalog.class);
    cr.setFetchMode("bookList", FetchMode.JOIN);
    cr.add(Restrictions.eq("name", "心理"));
    List<BookCatalog> bookCatalogList = cr.list();
    //使用Set接口的实现类HashSet来过滤重复的数据(HashSet中不会存储相同的值)
    HashSet<BookCatalog> bookCatalogSet = new HashSet<BookCatalog>(bookCatalogList);

    criteria.setFetchModel("propName", FetchMode.JOIN) 等同于在关联对象上@ManyToOne(fetch = FetchType.EAGER)@OneToMany(fetch = FetchType.EAGER)

    加载策略 作用
    FetchType.LAZY 懒加载,在访问关联对象的时候加载(即从数据库读入内存)
    FetchType.EAGER 立刻加载,在查询主对象的时候同时加载关联对象
    FetchMode.JOIN 始终立刻加载,使用外连(outer join)查询的同时加载关联对象,忽略FetchType.LAZY设定
    FetchMode.SELECT 默认懒加载(除非设定关联属性lazy=false)
    当访问每一个关联对象时加载该对象,会累计产生N+1条sql语句
    FetchMode.SUBSELECT 默认懒加载(除非设定关联属性lazy=false)
    在访问第一个关联对象时加载所有的关联对象。会累计产生两条sql语句。且FetchType设定有效。
  9. Example

    // Example类允许你通过一个给定实例 构建一个条件查询
    Book book = new Book();
    book.setAuthor("森");
    //注意:如何实体类中如果有int 或者doubole 类型的值而没有设置值,一定要加 excludeZeroes() 条件
    Example eqAuthorExample = Example.create(book).excludeZeroes().enableLike(MatchMode.ANYWHERE);
    // 查询
    Criteria cr = session.createCriteria(Book.class);
    cr.add(eqAuthorExample);
    List<Book> bookList = cr.list();
    • Example#excludeZeroes() 排除等于0值的属性
    • Example#excludeProperty("propName") 排除指定的属性
    • Example#ignoreCase() 忽略大小写
    • Example#enableLike() 开启like
  10. Projections 投影

    // Projections是 Projection 的实例工厂。我们通过调用 setProjection()应用投影到一个查询
    Criteria cr = session.createCriteria(Book.class);
    cr.setProjection(Projections.rowCount());
    cr.add(Restrictions.gt("price", new BigDecimal(20)));
    List list = cr.list();
    // 输出结果:[2]

    多个统计投影:

    // 当执行多个统计投影时,会获取一个List,并且是一个Object类型的List,其中依次包含所有的统计投影结果。
    Criteria cr = session.createCriteria(Book.class);
    ProjectionList projectionList = Projections.projectionList();
    projectionList.add(Projections.rowCount());
    projectionList.add(Projections.avg("price"));
    projectionList.add(Projections.max("price"));
    projectionList.add(Projections.min("price"));
    projectionList.add(Projections.sum("price"));
    projectionList.add(Projections.count("author"));
    projectionList.add(Projections.countDistinct("author"));
    cr.setProjection(projectionList);
    List<Object[]> list = cr.list();
    for(Object[] arr : list) {
    System.out.println(Arrays.asList(arr));
    }
    // 输出结果:[5, 22.42, 39.90, 5.00, 112.10, 5, 4]

    别名 alias :

    Criteria cr = session.createCriteria(Book.class);
    cr.setProjection(Projections.alias(Projections.groupProperty("author"), "aur"));
    cr.addOrder(Order.asc("aur"));
    List list = cr.list();
    System.out.println(list); Criteria cr = session.createCriteria(Book.class);
    cr.setProjection(Projections.groupProperty("author").as("aur"));
    cr.addOrder(Order.asc("aur"));
    List list = cr.list();
    System.out.println(list); //输出结果:[乔纳森·海特, 刘慈欣, 吴承恩, 艾略特·阿伦森]

hibernate基础查询语句使用的更多相关文章

  1. HQL基础查询语句

    HQL基础查询语句 1.使用hql语句检索出Student表中的所有列 //核心代码 @Test public void oneTest() { Query query=session.createQ ...

  2. Hibernate HQL查询语句总结

    Hibernate HQL查询语句总结 1. 实体查询:有关实体查询技术,其实我们在先前已经有多次涉及,比如下面的例子:String hql="from User user ";L ...

  3. Hibernate常用查询语句

    Hibernate常用查询语句 Hib的检索方式1'导航对象图检索方式.通过已经加载的对象,调用.iterator()方法可以得到order对象如果是首次执行此方法,Hib会从数据库加载关联的orde ...

  4. hibernate生成查询语句但查不到数据

    hibernate能够生成查询语句 说明它已经进行了查询操作 返回结果数据记录为0  很可能出现的情况 是  :该查询未未访问到指定数据库表. 当使用的数据库为oracle数据库时,你会在bean配置 ...

  5. SQL Serever学习9——基础查询语句

    SQL语言概述 SQL是结构化查询语言(Structure Query Language),1974年提出,1979年被IBM实现,SQL语言已经成为关系型数据库的标准语言. 包括: DDL数据定义语 ...

  6. sql基础查询语句

    数据库文件百度云地址:www.pan.baidu.com 脚步:下载博客园文件:select_learn.rar 1.TOP限制返回行数[percent] * from book_info --显示前 ...

  7. PL/SQL第三章 基础查询语句

    --查询所有列 select * from tab_name|view_name; SELECT * FROM emp; SELECT * FROM (SELECT * FROM emp); --查询 ...

  8. oracle 基础查询语句

    select abs(10) from dual; --取绝对值select ceil(3.6) from dual;--向上取整 select power(2,3) from dual;--2的3次 ...

  9. Hibernate查询语句

    1 hql查询 Hibernate的查询语句,hiberante提供的面向对象的查询语言,和sql语句的语法的相似.而且严格区分大小写. 1.1 from字句 /** * hql: from 字句 * ...

  10. MySQL 查询常用操作(0) —— 查询语句的执行顺序

    MySQL中明确查询语句的执行顺序极其重要,了解执行顺序才不至于犯一些简单错误,例如having 后面是否可以使用 select 中重命名的列名等问题.另外SQL中实际使用最频繁的就是查询(Quein ...

随机推荐

  1. 从Delphi到Lazarus——Lazarus开发环境使用入门教程

    0.前言 曾经有过更换开发环境体验的编程爱好者都会有同样的感受:打开新更换的开发环境后,看到陌生的界面无从下手.想写一段小程序试一试,却你找不到自己需要的组件在哪里. 其实,我们每到一个新地方,首先要 ...

  2. 《前端运维》五、k8s--4机密信息存储与统一管理服务环境变量

    一.储存机密信息 Secret 是 Kubernetes 内的一种资源类型,可以用它来存放一些机密信息(密码,token,密钥等).信息被存入后,我们可以使用挂载卷的方式挂载进我们的 Pod 内.当然 ...

  3. 鸿蒙UI布局实战 —— 个人中心页面开发

    1.前言 接下里我们将开启"鸿蒙UI布局系列"的学习,第一站:学习线性布局(Row/Column)+ 弹性布局(Flex) 在展开学习前,先上一个实战demo--开发一个个人中心页 ...

  4. tableau连接不上mysql或不显示mysql表的终极解决方法

    [报错一]连不上mysql An error occurred while communicating with MySQL The connection to the data source mig ...

  5. 有关终端Github无法访问,connection timed out:443等问题

    有关终端Github无法访问,connection timed out:443等问题 SSL_connect: Operation timed out in connection to github. ...

  6. 技术实践|Redis基础知识及集群搭建(下)

    ​ Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.本篇文章围绕Redis基础知识及集群搭建相关内容进行了分享 ...

  7. 【Python】【爬虫】【爬狼】001_urllib_get_获取响应结果页面代码

    情况说明 本节课我们要处理的网站是 www.yhdmp.cc 注意:腾讯报毒该网址.问题不大,基本这种盗版动漫的网站都会报毒吧.如果不放心可以自己找个其他的网站爬,我这个也是随便找的. 该网站搜索提交 ...

  8. 【Javaweb】【答卷】萌狼蓝天大二上学期期末Javaweb考试复习卷(一)

  9. 【C#】【平时作业】习题-11-ADO.NET

    选择题 1.下列ASP.NET语句(B)正确地创建了一个与mySQL数据库和服务器的连接. A.SqlConnection con1 = new Connection("Data Sourc ...

  10. 【前端】CSS:border

    border 是CSS中用于设置元素边框的. 第一个参数为线的粗细.除了数字型值外,还可以写: thin(细线) medium(中粗线) thick(粗线) 第二个参数是线条样式,可选参数如下: 小圆 ...