Получение vs. Загрузка в Hibernate

В Hibernate существует концепция получения одной строки. Для получения одной строки в соответствующей таблице базы данных мы будем использовать либо get() или load().

get()

get() всегда обращается к базе данных.

Если найден сериализуемый идентификатор, то мы получим соответствующие детали.

Пример

SwingBowlers swingBowlers = (SwingBowlers) openSession.get(SwingBowlers.class,1);

Сериализуемый идентификатор — 1 (jerSeyNo) –> Первичный ключ

Если идентификатор сериализации не найден, то результатом будет null.load()

load() всегда создает объект-заместитель.Если идентификатор сериализации найден, то мы получим соответствующие детали.        

Пример

SwingBowlers swingBowlers = (SwingBowlers) openSession.get(SwingBowlers.class,1);

System.out.println(swingBowlers);

Идентификатор сериализации 1 (jerSeyNo) –> Первичный ключ

Если идентификатор сериализуемого объекта не найден, то мы получим результат org.hibernate.ObjectNotFoundException.  

Проверьте, генерируется ли запрос, хотя мы используем метод load, так как пытаемся распечатать детали объекта. [System.out.println(swingBowlers);]. Но это происходит только от объекта-заместителя [Dummy Object].

Давайте рассмотрим это на практике.

HibernateTutorialRun.java

Java

 

package com.blogspot.javacodebypj;

import com.blogspot.javacodebypj.dao.SwingBowlersDaoImpl;

public class HibernateTutorialRun {

    public static void main(String[] args) {

        SwingBowlersDaoImpl sbdi = new SwingBowlersDaoImpl();

        sbdi.getSwingBowlers();

        }

}

Пояснение: HibernateTutorialRun — это класс для запуска приложения HibernateTutorial, и мы используем его без сервера. Hibernate может работать как с сервером, так и без него. Мы создали метод main, и в нем просто создали объект для соответствующего класса SwingBowlersDaoImpl. Затем мы просто используем ссылку на этот объект, вызывая соответствующий метод.

SwingBowlersDao.java

Java

 

package com.blogspot.javacodebypj.dao;

import org.hibernate.Session;

import org.hibernate.SessionFactory;

import com.blogspot.javacodebypj.domain.SwingBowlers;

import com.blogspot.javacodebypj.util.HibernateUtil;



public class SwingBowlersDaoImpl implements SwingBowlersDao {

    @Override

    public void getSwingBowlers() {

        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();

        Session openSession = sessionFactory.openSession();

       // используя метод load

        SwingBowlers swingBowlers = (SwingBowlers) openSession.load(SwingBowlers.class, 1);

        System.out.println(swingBowlers);

    }

}

Объяснение:Мы только что создалиSwingBowlersDaoImplкласс и реализовали его с помощьюSwingBowlersDao, и мы собираемся переопределить соответствующий метод. Мы пытаемся вызватьHibernateUtilкласс метода, а именноgetSessionFactoryметод, мы получимSessionFactoryобъект, и с помощьюSessionFactoryобъекта ссылки, мы вызываемopenSessionметод. Затем мы получимSessionобъект.

Как только мы получим объект сессии с этой сессией, мы можем использовать либо метод load, либо get, и мы просто приводим к соответствующему классу из-за метода load или get, который возвращает Object. Надеюсь, вы понимаете концепцию наследования и приведения типов в Java.

SwingBowlers.java

Java

 

package com.blogspot.javacodebypj.domain;

import javax.persistence.Column;

import javax.persistence.Entity;

import javax.persistence.Id;

@Entity

public class SwingBowlers {

    @Id

    @Column(length = 3)

    private int jerseyNo;

    @Column(length = 15)

    private String bowlerName;

    @Column(length = 10)

    private String country;

    public int getJerseyNo() {

        return jerseyNo;

    }

    public void setJerseyNo(int jerseyNo) {

        this.jerseyNo = jerseyNo;

    }

    public String getBowlerName() {

        return bowlerName;

    }

    public void setBowlerName(String bowlerName) {

        this.bowlerName = bowlerName;

    }

    public String getCountry() {

        return country;

    }

    public void setCountry(String country) {

        this.country = country;

    }

    @Override

    public String toString() {

        return "SwingBowlers [jerseyNo=" + jerseyNo + ", bowlerName=" + bowlerName + ", country=" + country + "]";

    }

}

Объяснение: Так как мы сопоставляем поля с столбцами базы данных. Если имя поля совпадает с именем столбца в таблице базы данных, то нет необходимости указывать значение столбца на уровне аннотации. Аналогично, имя таблицы также совпадает с именем класса SwingBowlersпоэтому мы не аннотируем с помощью @Table. Чтобы сделать его доменным классом, мы используем аннотацию @Entity в верхней части соответствующего класса.

HibernateUtil.java

Java

 

package com.blogspot.javacodebypj.util;

import org.hibernate.SessionFactory;

import org.hibernate.cfg.Configuration;

public class HibernateUtil {

    private static SessionFactory sessionFactory;

    private HibernateUtil() {

    }

    public static SessionFactory getSessionFactory() {

        if (sessionFactory == null) {

            Configuration conf = new Configuration().configure();

            sessionFactory = conf.buildSessionFactory();

        }

        return sessionFactory;

    }

}

Объяснение: Мы только что создали SessionFactory как синглтон класс. 

hibernate.cfg.xml

Java

 

<?xml version='1.0' encoding='UTF-8'?>

<!DOCTYPE hibernate-configuration PUBLIC

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">



<hibernate-configuration>

    <session-factory>

        <property name="connection.driver_class">com.mysql.jdbc.Driver

        </property>

        <property name="connection.url">jdbc:mysql://localhost:3306/cricketer</property>

        <property name="connection.username">root</property>

        <property name="connection.password">myRoot4*</property>



        <property name="dialect">org.hibernate.dialect.MySQL8Dialect</property>

        <property name="show_sql">true</property>

        <property name="hbm2ddl.auto">update</property>



        <mapping class="com.blogspot.javacodebypj.domain.SwingBowlers" />



    </session-factory>

</hibernate-configuration>

Объяснение: В этом мы имеем три раздела:  

  1. Свойства, связанные с базой данных
  2. Свойства, связанные с Hibernate
  3. Класс отображения

Как вы знаете, мы не используем файл отображения XML в Hibernate, поэтому мы только упомянули класс отображения.

диалект:Он используется для генерации запросов с учетом базы данных. В этом приложении мы используем базу данных MySQL.

show_sql:После генерации запросов нам нужно увидеть эти запросы, поэтому нам нужно указать их как true.

pom.xml

Java

 

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">

    <modelVersion>4.0.0</modelVersion>

    <groupId>com.blogspot.javacodebypj</groupId>

    <artifactId>HibernateTutorial</artifactId>

    <version>0.0.1-SNAPSHOT</version>

    <name>HibernateTutorial</name>

    <description>HibernateTutorial by Ponnam Jay</description>

    <properties>

        <maven.compiler.target>1.8</maven.compiler.target>

        <maven.compiler.source>1.8</maven.compiler.source>

    </properties>

    <dependencies>

        <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core -->

        <dependency>

            <groupId>org.hibernate</groupId>

            <artifactId>hibernate-core</artifactId>

            <version>5.6.14.Final</version>



        </dependency>

        <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->

        <dependency>

            <groupId>mysql</groupId>

            <artifactId>mysql-connector-java</artifactId>

            <version>8.0.28</version>

        </dependency>



    </dependencies>

</project>

Пояснение:Мы только что создали структуру проекта Maven с помощью Eclipse IDE как простой проект Maven. Добавили зависимости, такие как hibernate-core, mysql-connector-java и использовали Java 1.8, чтобы увидеть в pom.xml в разделе свойств целевой и исходный код.

Детали базы данных


Заключение

Если вы хотите извлечь (получить) одну строку (одну запись), то можете использовать либо метод get, либо метод load.

Source:
https://dzone.com/articles/hibernate-get-vs-load