JAVA:IDEA使用Hibernate(2)

1、打开IDEA新建项目

勾选Hibernate、勾选下方生成相关配置和类

下方选择Download,如果使用本地已经下载的包则选择 Use Library ,路径选到包里面的require里导入即可

2、添加mysql类库支持

File ——> Project Structure ——> Libraries ——> + ——>搜索类库确认ok即可

这里使用mysql-connector-java

3 IDEA连接mysql数据库

IDEA右侧toolbar里面选择Database——> +——>mysql

填写数据库信息,即可连接上数据库;注意:如果是首次使用 : Test Connection 是灰色的,在面板最下面点击 Download支持库即可测试连接

4、创建包

点击项目的src——>  右键新建Package ——> 输入包名称 com.practice.data ; 并且分别通过工程上面的toolbar创建两个子包entities、utils;注意路径都在 com.practice.data下面

右键main.java——> Refactor——>Rename ——> 重命名为HibernateSessionFactory,拖入utils

5、自动根据已经存在的数据库表生成Hibernate实体与xml

Persistence

 

如下配置ok生成,然后查看我们的entities包已经生成了对应文件

打开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/only_rls</property>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!-- <property name="connection.username"/> -->
        <!-- <property name="connection.password"/> -->
        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">4</property>

        <!-- SQL dialect 数据库方言-->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

        <!-- Enable Hibernate's automatic session context management -->
        <property name="current_session_context_class">thread</property>

        <!-- Disable the second-level cache  -->
        <!--<property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>-->
        <!--以格式良好的方式显示SQL语句-->
        <property name="format_sql">true</property>
        <!-- 控制台显示SQL语句 -->
        <property name="show_sql">true</property>

        <!-- Drop and re-create the database schema on startup -->
        <!-- DB schema will be updated if needed 自动更新数据库-->
        <property name="hbm2ddl.auto">update</property>
        <mapping class="com.practice.data.entities.RlsUserEntity"/>
        <mapping resource="com/practice/data/entities/RlsUserEntity.hbm.xml"/>
    </session-factory>
</hibernate-configuration>

Hibernate常用类

SessionFactory

配置对象被用于创造一个 SessionFactory 对象,使用提供的配置文件为应用程序依次配置 Hibernate,并允许实例化一个会话对象。SessionFactory 是一个线程安全对象并由应用程序所有的线程所使用。

SessionFactory 是一个重量级对象所以通常它都是在应用程序启动时创造然后留存为以后使用。每个数据库需要一个 SessionFactory 对象使用一个单独的配置文件。所以如果你使用多种数据库那么你要创造多种 SessionFactory 对象。

Session

一个会话被用于与数据库的物理连接。Session 对象是轻量级的,并被设计为每次实例化都需要与数据库的交互。持久对象通过 Session 对象保存和检索。

Session 对象不应该长时间保持开启状态因为它们通常情况下并非线程安全,并且它们应该按照所需创造和销毁。

Transaction

一个事务代表了与数据库工作的一个单元并且大部分 RDBMS 支持事务功能。在 Hibernate 中事务由底层事务管理器和事务(来自 JDBC 或者 JTA)处理。

这是一个选择性对象,Hibernate 应用程序可能不选择使用这个接口,而是在自己应用程序代码中管理事务。


Query 对象

Query 对象使用 SQL 或者 Hibernate 查询语言(HQL)字符串在数据库中来检索数据并创造对象。一个查询的实例被用于连结查询参数,限制由查询返回的结果数量,并最终执行查询。

原文地址:https://www.cnblogs.com/xmai/p/8124383.html