Intellij IDEA的Hibernate简单应用

所有的Hibernate应用中都会访问Hibernate的5个核心接口。
  Configuration接口:配置Hibernate,根启动Hibernate,创建SessionFactory对象。
  SessionFactory接口:初始化Hibernate,充当数据存储源的代理,创建Session对象。
  Session接口:负责保存、更新、删除、加载和查询对象。
  Transaction接口:管理事务。
  Query和Criteria接口:执行数据库查询。
  1.Configuration接口
  Configuration对象用于配置并且启动Hibernate。Hibernate应用通过Configuration实例来指定对象-关系映射文件的位置或者动态配置Hibernate的属性,然后创建SessionFactory实例。
  2.SessionFactory接口
  一个SessionFactory实例对应一个数据存储源,应用从SessionFactory中获得Session实例。SessionFactory有以下特点:
  它是线程安全的,这意味着它的同一个实例可以被应用的多个线程共享。
  它是重量级的,这意味着不能随意创建或销毁它的实例。如果应用只访问一个数据库,只需要创建一个SessionFactory实例,在应用初始化的时候创建该实例。如果应用同时访问多个数据库,则需要为每个数据库创建一个单独的SessionFactory实例。
  之所以称SessionFactory是重量级的,是因为它需要一个很大的缓存,用来存放预定义的SQL语句以能映射元数据等。用户还可以为SesionFactory配置一个缓存插件,这个缓存插件被称为Hibernate的第二级缓存。,该缓存用来存放被工作单元读过的数据,将来其他工作单元可能会重用这些数据,因此这个缓存中的数据能够被所有工作单元共享。一个工作单元通常对应一个数据库事务。
3.Session接口
  Session接口是Hibernate应用使用最广泛的接口。Session也被称为持久化管理器,它提供了和持久化相关的操作,如添加、更新、删除、加载和查询对象。
  Session有以下特点:
  不是线程安全的,因此在设计软件架构时,应该避免多个线程共享同一个Session实例。
  Session实例是轻量级的,所谓轻量级,是指它的创建和销毁不需要消耗太多的资源。这意味着在程序中可以经常创建和销毁Session对象,例如为每个客户请示分配单独的Session实例,或者为每个工作单元分配单独的Session实例。
  Session有一个缓存,被称为Hibernate的第一级缓存,它存放被当前工作单元加载的对象。每个Session实例都有自己的缓存,这个Sesion实例的缓存只能被当前工作单元访问。
  4.Transaction接口
  Transaction接口是Hibernate的数据库事务接口,它对底层的事务接口做了封装,底层事务接口包括:
  JDBC API、JTA(Java Transaction API)、CORBA(Common Object Requet Broker Architecture)API
  Hibernate应用可通过一致的Transaction接口来声明事务边界,这有助于应用在不同的环境容器中移植。尽管应用也可以绕过Transaction接口,直接访问底层的事务接口,这种方法不值得推荐,因为它不利于应用在不同的环境移植。
  5.Query和Criteria接口
  Query和Criteria接口是Hibernate的查询接口,用于向数据库查询对象,以及控制执行查询的过程。Query实例包装了一个HQL查询语句,HQL查询语句和SQL查询语句有些相似,但HQL查询语句是面向对象的,它引用类句及类的属性句,而不是表句及表的字段句。Criteria接口完全封装了基于字符串的查询语句,比Query接口更加面向对象,Criteria接口擅长执行动态查询。
  Session接口的find()方法也具有数据查询功能,但它只是执行一些简单的HQL查询语句的快捷方法,它的功能远没有Query接口强大。

新建表

create  table user(
  id int(10) unsigned not null auto_increment,
  username varchar(50) default null ,
  password varchar(50) default  null,
  email varchar(50) default  null,
  primary key (id),
  unique key(id),
  key id_2(id)
)engine=InnoDB auto_increment=1 DEFAULT  charset =utf8

1)创建一个空白Project,名为:HibernateProject。
2)创建一个Module,名为:HibernateModule,选择“Web Application”和“Hibernate”。选择“create default hibernate configuration in project configuration”和“Download”,点击“Configure”,

选择Hibernate 5.2-5,2。确定即可。IDEA会自动下载相关的Jar包,并自动生成一个hibernate.cfg.xml配置文件

3)调整一个项目的结构,将lib文件夹移动到web/WEB-INF路径下,在web/WEB-INF路径下生成一个文件夹classes。快捷键:Ctrl + Alt + Shift + S ,弹出Project Module。配置Paths和Dependencies。

4)将额外需要的JAR包复制到lib文件夹中,比如MySQL驱动包mysql-connector-java-8.0.11-bin.jar,测试包junit-4.10.jar。
 
5)根据数据库hibernate5中的user表,生成UserEntity类。有两种生成方式,一种是生成UserEntity类并生成相应的配置文件UserEntity.hbm.xml 文件。另外一种是利用标注的方式进行数据库表与实体类的属性的匹配。这里选择第二种方式。

选择左边的Persistence,选择对应的Module的hibernate.cfg.xml,注意选择的是图标是数据库样式的,右键 -> Generate Persistence Mapping -> By Database Schema

选择数据库源,就是刚刚测试连接的数据库;输入包名,它会自动创建包的;由于这里只是简单的演示如何利用Hibernate操作数据库,所以只是简单的选择其中一个表来做实验,比如选择hibernate5.user。并且将右下方的“Generate Column Properties”勾上。如果选择的是第一种操作方式,则将右下方的“Generate Separate XML per Entity”勾选上,即为每一个表所对应的实体类生成一个配置文件。确定即可。 

 

6)自动生成的实体类UserEntity。

package com.tanlei.pojo;

import javax.persistence.*;
import java.util.Objects;

/**
 * @author <a href="mailto:lei.tan@vtradex.net">谭磊</a>
 * @since 2018-12-28 10:47
 */
@Entity
@Table(name = "user", schema = "hibernate5", catalog = "")
public class UserEntity {
    private int id;
    private String username;
    private String password;
    private String email;

    @Id
    @Column(name = "id", nullable = false)
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    @Basic
    @Column(name = "username", nullable = true, length = 50)
    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    @Basic
    @Column(name = "password", nullable = true, length = 50)
    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Basic
    @Column(name = "email", nullable = true, length = 50)
    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        UserEntity that = (UserEntity) o;
        return id == that.id &&
                Objects.equals(username, that.username) &&
                Objects.equals(password, that.password) &&
                Objects.equals(email, that.email);
    }

    @Override
    public int hashCode() {
        return Objects.hash(id, username, password, email);
    }
}
View Code

7)配置hibernate.cfg.xml 如下。

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate5</property>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.username">root</property>
        <property name="connection.password">password</property>
        <property name="current_session_context_class">thread</property>
        <property name="show_sql">true</property>
        <property name="hbm2ddl.auto">update</property>
        <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
        <mapping class="com.tanlei.pojo.UserEntity"/>
        <!-- DB schema will be updated if needed -->
        <!-- <property name="hbm2ddl.auto">update</property> -->
    </session-factory>
</hibernate-configuration>

8)生成测试路径。在Module路径下生成一个文件夹,与src同级,名为test,点击文件夹test,右键,选择Mark Directory As - > Test Sources Root。

 9)生成测试类。

import com.tanlei.pojo.UserEntity;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Before;
import org.junit.Test;

/**
 * @author <a href="mailto:lei.tan@vtradex.net">谭磊</a>
 * @since 2018-12-28 10:58
 */
public class DaoTest {

    Configuration configuration=null;
    SessionFactory sessionFactory=null;
    Session session=null;
    Transaction transaction=null;
    @Before
    public void init(){
        configuration=new Configuration().configure("/hibernate.cfg.xml");
        sessionFactory=configuration.buildSessionFactory();
        session=sessionFactory.openSession();
        transaction=session.beginTransaction();
    }

    /**
     *
     * 增加一个用户
     */
    @Test
    public void insert(){
        UserEntity userEntity=new UserEntity();
        userEntity.setUsername("admin");
        userEntity.setPassword("admin");
        userEntity.setEmail("273008379@qq.com");
        session.save(userEntity);
        transaction.commit();
    }

    /**
     *修改一个用户
     */
    @Test
    public void update(){
        UserEntity userEntity=session.load(UserEntity.class, new Integer(2));
        userEntity.setUsername("tt");
        session.update(userEntity);
        transaction.commit();
        session.close();
    }

    /**
     * 查找一个用户
     */
    @Test
    public void select(){
        UserEntity userEntity=session.load(UserEntity.class,new Integer(2));
        transaction.commit();
        System.out.println(userEntity.getId()+userEntity.getUsername()+userEntity.getEmail()+userEntity.getPassword());
        session.close();
    }

    /**
     * 删除一个用户
     */
    @Test
    public void delete(){
        UserEntity userEntity=session.load(UserEntity.class, new Integer(2));
        session.delete(userEntity);
        transaction.commit();
        session.close();
    }
}
View Code

10)运行测试类,可以一个一个方法的进行运行,也可以在类名处将所有的测试方法都一起运行。全部运行成功!

原文地址:https://www.cnblogs.com/tanlei-sxs/p/10190008.html