Java Hibernate中的查询方式有哪些

蜗牛 互联网技术资讯 2023-04-29 52 0

这篇“Java Hibernate中的查询方式有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java Hibernate中的查询方式有哪些”文章吧。

    Hibernate 是一个开源的 ORM(对象关系映射)框架,它可以将 Java 对象映射到数据库表中,实现对象与关系数据库的映射。Hibernate 提供了多种查询方式,包括 OID 检索、对象导航检索、HQL 检索、QBC 检索和 SQL 检索。除此之外,Hibernate 还提供了多种抓取策略,包括立即抓取、延迟抓取和批量抓取。

    查询方式

    OID 检索

    OID(Object IDentifier)是 Hibernate 中每个持久化对象的唯一标识符。OID 检索是通过调用 get() 或 load() 方法来获得一个持久化对象的方式。这两个方法的区别在于当对象不存在时,get() 方法返回 null,而 load() 方法会抛出 ObjectNotFoundException 异常。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    User user = (User) session.get(User.class, 1L);
    tx.commit();
    session.close();

    对象导航检索

    对象导航检索是通过调用一个持久化对象的 getter 方法获得其他持久化对象的方式。例如,如果一个 User 对象有一个关联的 Order 对象,可以通过调用 user.getOrders() 方法来获得该 User 的所有订单。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    User user = (User) session.get(User.class, 1L);
    Set<Order> orders = user.getOrders();
    tx.commit();
    session.close();

    HQL 检索

    HQL(Hibernate Query Language)是一种面向对象的查询语言,类似于 SQL,但是它查询的是对象,而不是表。HQL 使用类名和属性名来表示表和字段,可以使用类似于 SQL 的语法进行查询。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    List<User> users = session.createQuery("from User").list();
    tx.commit();
    session.close();

    QBC 检索

    QBC(Query By Criteria)检索是一种基于 Criteria API 的查询方式,可以使用一组条件来查询对象。Criteria API 提供了一种类型安全的查询方式,可以通过代码来构建查询条件,从而避免了字符串拼接的风险。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    Criteria criteria = session.createCriteria(User.class);
    List<User> users = criteria.add(Restrictions.eq("name", "John")).list();
    tx.commit();
    session.close();

    SQL 检索

    SQL 检索是一种基于 SQL 语句的查询方式,可以使用原生的 SQL 语句来查询对象。使用 SQL 检索的一个常见场景是查询复杂的报表数据。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    SQLQuery query = session.createSQLQuery("select * from user");
    List<User> users = query.list();
    tx.commit();
    session.close();

    抓取策略

    立即抓取

    立即抓取是指在加载一个持久化对象时,同时加载该对象关联的其他持久化对象。这种方式可以避免在后续访问关联对象时产生额外的 SQL 查询,提高了系统的性能。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    List<User> users = session.createQuery("from User u left join fetch u.orders").list();
    tx.commit();
    session.close();

    延迟抓取

    延迟抓取是指当访问一个持久化对象的关联对象时,才去加载该关联对象。这种方式可以减少不必要的 SQL 查询,提高系统的性能。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    User user = (User) session.get(User.class, 1L);
    Hibernate.initialize(user.getOrders());
    tx.commit();
    session.close();

    抓取策略

    Hibernate 提供了多种抓取策略,包括 join、select、subselect 和 batch 策略。这些策略可以在查询时指定,从而控制 Hibernate 的抓取行为。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    Criteria criteria = session.createCriteria(User.class);
    criteria.setFetchMode("orders", FetchMode.JOIN);
    List<User> users = criteria.list();
    tx.commit();
    session.close();

    批量抓取

    批量抓取是指在加载一批持久化对象时,同时加载这些对象关联的其他持久化对象。这种方式可以减少不必要的 SQL 查询,提高系统的性能。

    示例代码:

    Session session = sessionFactory.openSession();
    Transaction tx = session.beginTransaction();
    List<User> users = session.createQuery("from User u left join fetch u.orders").setFirstResult(0).setMaxResults(10).list();
    tx.commit();
    session.close();

    以上就是关于“Java Hibernate中的查询方式有哪些”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注蜗牛博客行业资讯频道。

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    评论

    有免费节点资源,我们会通知你!加入纸飞机订阅群

    ×
    天气预报查看日历分享网页手机扫码留言评论Telegram