Спящий режим — собственный SQL

Опубликовано: 27 Сентября, 2022

Спящий режим с помощью собственного средства SQL может напрямую взаимодействовать с базой данных, такой как MySQL, Oracle и т. Д., И все запросы к базе данных могут выполняться с помощью этого средства. Эта функция очень полезна, если приложение является старым и работает в течение длительного времени. Внезапно мы не можем вернуть новые изменения, но вместо этого с помощью средств Native SQL мы можем работать над этим. В основном для поддержки старых приложений мы можем перейти на Hibernate — Native SQL.

Пример проекта

Структура проекта:

Мы собираемся увидеть проект, управляемый maven. Следовательно, в качестве первого шага давайте посмотрим pom.xml, в котором указаны все зависимости, свойства и т. д.

пом.xml

XML




         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
                             http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>Hibernate-NativeSQL-SampleApplication</groupId>
  <artifactId>Hibernate-NativeSQL-SampleApplication</artifactId>
  <version>0.0.1-SNAPSHOT</version>
    <dependencies>
       
          <!-- Much essential hibernate core dependency -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>4.3.0.Final</version>
        </dependency>
       
        <!-- As we are connecting with MySQL, this is needed -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.34</version>
        </dependency>
       
    </dependencies>
   
    <!-- Higher java versions are preferred, atleast 1.8 -->
    <properties>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>
   
</project>

Важные файлы для проекта

hibernate.cfg.xml

Здесь указываются свойства Hibernate.

XML




<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
<hibernate-configuration>
    <session-factory>
        <!--  As we are connecting mysql, those driver classes,
              database name, username and password are specified
              Please change the information as per your requirement -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/test?serverTimezone=UTC</property>       
        <property name="connection.username">root</property>
        <property name="connection.password">admin</property>
       
        <!--  We are going to connect studentsdetails.hbm.xml
              which has the table information about studentsdetails
              which is present in mysql -->
        <mapping resource="studentsdetails.hbm.xml" />
    </session-factory>
</hibernate-configuration>

Студенческие детали.hbm.xml

XML




<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
  "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
<hibernate-mapping>
    <!--  studentsdetails is the mySQL table and corresponding
           POJO class is  com.gfg.hibernate.pojo.StudentsDetails-->
    <class name="com.gfg.hibernate.pojo.StudentsDetails" table="studentsdetails"
        schema="test">
        <id name="id" column="id">
            <generator class="increment" />
        </id>
        <property name="name" column="name" />
        <property name="caste" column="caste" />
        <property name="neetMarks" column="neetMarks" />
        <property name="gender" column="gender"/>
    </class>
</hibernate-mapping>

Давайте теперь посмотрим на класс POJO

СтудентыDetails.java

Java




// Each and every column must represent the
// column of mysql table studentsDetails
public class StudentsDetails {
    private int id;
    private String name;
    private String caste;
    private int neetMarks;
    private String gender;
 
    // For all columns, corresponding
    // getter and setter are added
    public int getId()
    {
        return id;
    }
    public void setId(int id)
    {
        this.id = id;
    }
    public String getName()
    {
        return name;
    }
    public void setName(String name)
    {
        this.name = name;
    }
    public String getCaste()
    {
        return caste;
    }
    public void setCaste(String caste)
    {
        this.caste = caste;
    }
    public int getNeetMarks()
    {
        return neetMarks;
    }
    public void setNeetMarks(int neetMarks)
    {
        this.neetMarks = neetMarks;
    }
    public String getGender()
    {
        return gender;
    }
    public void setGender(String gender)
    {
        this.gender = gender;
    }
}

Таким образом, вышеперечисленные файлы являются связующим носителем. Давайте также посмотрим на таблицу MySQL

Предположим, что у нас есть некоторый набор записей в этом

Теперь давайте посмотрим, как писать запросы для связи с MySQL и узнаем подробности.

Java




package com.gfg.hibernate;
 
import java.util.Iterator;
import java.util.List;
 
import org.hibernate.Filter;
import org.hibernate.Hibernate;
import org.hibernate.Query;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.type.IntegerType;
import org.hibernate.type.StringType;
 
import com.gfg.hibernate.pojo.StudentsDetails;
 
public class Main {
 
    public static void main(String[] args)
    {
        // Refer the hibernate.cfg.xml
        Configuration configuration = new Configuration()
                                          .configure("hibernate.cfg.xml");
        StandardServiceRegistryBuilder builder = new StandardServiceRegistryBuilder()
                                                     .applySettings(configuration.getProperties());
 
        // SessionFactory will contain all the database property
        // details which are pulled from above hibernate.cfg.xml file
        // As application refers the database, it is required.
        // It is a threadsafe object
        SessionFactory factory = configuration.buildSessionFactory(builder
                                                                       .build());
 
        // To get a physical connection
        Session session = factory.openSession();
 
        // Query the database by means of specific tablename
        // straightaway. SQL should be like how we do
        // from SQLCommandline or workbench
        String studentsQuery = "select * from studentsdetails";
 
        // New instance of Query for the given SQL
        SQLQuery sqlQuery1 = session.createSQLQuery(studentsQuery);
 
        // We will get the details via list
        List studentsList = sqlQuery1.list();
 
        Iterator studentsIterator = studentsList.iterator();
 
        while (studentsIterator.hasNext()) {
            Object[] object = (Object[])studentsIterator.next();
            System.out.println("Student Id : " + object[0] + " Student Name : " + object[1]
                               + " Caste : " + object[2]);
        }
 
        // Always good to clear
        // and close the session
        session.clear();
        session.close();
    }
}

Мы можем получить все детали благодаря функции Complete Row .

// Query the database by means of specific tablename straightaway. 
// SQL should be like how we do from SQLCommandline or workbench
String studentsQuery = "select * from studentsdetails";

// New instance of Query for the given SQL 
SQLQuery sqlQuery1 = session.createSQLQuery(studentsQuery);

Выход:

Если каждая строка преобразуется в объект класса POJO, мы можем использовать метод addEntity() SQLQuery.

Java




// addEntity
System.out.println("***********Entity*************");
String entityQuery = "select * from studentsdetails";
SQLQuery sqlQuery2 = session.createSQLQuery(entityQuery);
sqlQuery2.addEntity(StudentsDetails.class);
 
List studentsEntityList = sqlQuery2.list();
 
// list contains StudentsDetails class objects.
// So that we can directly cast into StudentsDetails type :
Iterator studentsEntityIterator = studentsEntityList.iterator();
 
while (studentsEntityIterator.hasNext()) {
    StudentsDetails student = (StudentsDetails)studentsEntityIterator.next();
    System.out.println("id : " + student.getId() + " Name : "
                       + student.getName() + " NEETMarks : " + student.getNeetMarks());
}

Выход:

Скалярные данные:

Если мы хотим частично выделить несколько столбцов одними средствами, это возможно с помощью addScalar(). Hibernate внутренне использует ResultSetMetaData. Нам нужно указать тип данных, когда мы используем addScalar().

Java




// addSclar
System.out.println("***********SCALAR*************");
 
String scalarQuery = "select * from studentsdetails";
SQLQuery sqlQuery3 = session.createSQLQuery(scalarQuery);
 
// As we are taking first 2 columns alone, we need to
// specify the name of the column and datatype here
sqlQuery3.addScalar("id", IntegerType.INSTANCE);
sqlQuery3.addScalar("name", StringType.INSTANCE);
List studentsScalarList = sqlQuery3.list();
Iterator studentsScalarIterator = studentsScalarList.iterator();
 
while (studentsScalarIterator.hasNext()) {
    Object[] object = (Object[])studentsScalarIterator.next();
    // Here also we can see only 2 column
    // retrieval because of addScalar()
    System.out.println("Id : " + object[0] + " Name : " + object[1]);
}

Выход:

Наконец, давайте посмотрим, как обновить данные

Java




// update
System.out.println("**********Update**********");
 
Transaction mySqlTransaction = session.beginTransaction();
 
// straight away righting update query specific to db
String updateQuery = "update studentsdetails set neetmarks=:neetmarks where id=:id";
SQLQuery sqlQuery4 = session.createSQLQuery(updateQuery);
sqlQuery4.setParameter("id", 1);
sqlQuery4.setParameter("neetmarks", 650);
sqlQuery4.executeUpdate();
 
// will do the changes permanent to database
mySqlTransaction.commit();
System.out.println("Completed");
 
// again check after doing committing
entityQuery = "select * from studentsdetails";
sqlQuery2 = session.createSQLQuery(entityQuery);
sqlQuery2.addEntity(StudentsDetails.class);