zoukankan      html  css  js  c++  java
  • 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)运行测试类,可以一个一个方法的进行运行,也可以在类名处将所有的测试方法都一起运行。全部运行成功!

  • 相关阅读:
    MyEclipse安装插件的三种方法和使用心得
    Rest-Assured
    HTTP Status 500
    ASP.NET C#_HTML练习
    Python网络管理模块Paramiko-代码实例
    CTF中遇到的php
    HTML,CSS,Javascript,PHP在网站结构中扮演的“角色”
    ctf中关于图片的隐写随笔(不全)
    Unicode和Ascii的区别
    1221作业
  • 原文地址:https://www.cnblogs.com/tanlei-sxs/p/10190008.html
Copyright © 2011-2022 走看看