zoukankan      html  css  js  c++  java
  • Hibernate入门

    -------------------------siwuxie095

       

       

       

       

       

       

       

       

    搭建 Hibernate 环境

       

       

    1、先下载相关库文件,下载链接:

       

    http://hibernate.org/orm/downloads/

       

       

    注意:这里选择下载 Hibernate 5.0 版本(或 5.1 亦可),

    下载后,将 hibernate-release-5.0.12.Final.zip 解压一览:

       

       

       

       

    hibernate-release-5.0.12.Final.zip 下载链接:

       

    https://sourceforge.net/projects/hibernate/files/hibernate-orm/5.0.12.Final/hibernate-release-5.0.12.Final.zip/download

       

       

       

    2、导入 Hibernate 的 jar 包,打开 lib 文件夹

       

       

       

    其中,lib equiredlibjpa 文件夹中的包(共 10 个包)必须要导入

       

       

       

       

       

    3、在使用 Hibernate 时,有日志信息输出,而 Hibernate 本身

    并没有日志输出的包,所以还要导入其它日志相关的包,如下:

       

    1)slf4j-api

       

    2)slf4j-log4j

       

    3)log4j

       

       

    SLF4J 下载链接:https://www.slf4j.org/dist/,其中包含 slf4j-api

    和 slf4j-log4j

       

       

    LOG4J 下载链接:https://www.apache.org/dist/logging/log4j/

    其中包含 log4j

       

       

    其实,Hibernate的 liboptionalehcache 文件夹下也有 slf4j-api:

       

       

       

       

    4、最后,需要下载 MySQL 的 JDBC 驱动,下载链接:

       

    https://dev.mysql.com/downloads/connector/j/

       

    其中,包含:mysql-connector-java

       

       

    另外,其 srclib 文件夹下,也有 slf4j-api:

       

       

       

       

    5、综上所述,共需 14 jar 包

       

       

       

       

       

       

       

       

    创建实体类

       

       

    包名:com.siwuxie095.entity

    类名:User.java

       

       

    User.java:

       

    package com.siwuxie095.entity;

       

    public class User {

       

    //Hibernate 要求实体类有一个属性唯一,即主键

    private int uid;

    private String username;

    private String password;

    private String address;

    public int getUid() {

    return uid;

    }

    public void setUid(int uid) {

    this.uid = uid;

    }

    public String getUsername() {

    return username;

    }

    public void setUsername(String username) {

    this.username = username;

    }

    public String getPassword() {

    return password;

    }

    public void setPassword(String password) {

    this.password = password;

    }

    public String getAddress() {

    return address;

    }

    public void setAddress(String address) {

    this.address = address;

    }

    }

       

       

    注意:使用 Hibernate 时,不需要自己手动创建表,Hibernate

    可以帮助我们把表自动创建出来

       

       

       

       

       

       

       

    创建 Hibernate 的映射配置文件

       

       

    配置实体类和数据库表一一对应关系(使用配置文件实现映射关系)

       

       

    1、创建 XML 格式的配置文件

       

    映射配置文件的名称和位置没有固定要求

       

    建议:在实体类所在包里创建,名称为:实体类名.hbm.xml

       

    hbm,即 Hibernate Mapping」

       

    具体到这里,即 在 com.siwuxie095.entity 包下创建 User.hbm.xml

       

       

       

    2、在配置文件中引入 XML 约束

       

    hibernate-mapping-3.0.dtd

       

    「XML约束有 DTDSchema 两种,在 Hibernate 的配置文件

    中引入的是 DTD 约束(目前)」

       

       

    该文件在 projecthibernate-coresrcmain esourcesorghibernate 文件夹下:

       

       

       

       

    User.hbm.xml 中添加如下约束:

       

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

    <!DOCTYPE hibernate-mapping PUBLIC

    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

       

       

       

    3、配置映射关系

       

    User.hbm.xml:

       

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

    <!DOCTYPE hibernate-mapping PUBLIC

    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

       

    <!--

    http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd

    dtd 文件是用于提示的文件,联网即有提示信息,也可

    手动添加:Window->Preferences->XML->XML Catalog

    点击 Add 添加即可,Location 即路径,Key 即上面的链接,

    Key type URI

    -->

    <!-- 根标签 -->

    <hibernate-mapping>

       

    <!-- (1)

    class 标签:配置实体类和数据库表的对应;

    name 属性:实体类的全路径,即全限定名;

    table 属性:数据库表的名称(数据库表由 Hibernate 自动生成) -->

    <class name="com.siwuxie095.entity.User" table="t_user">

    <!-- (2)

    id 标签:配置实体类 id 和表 id 对应(主键);

    name 属性:实体类里 id 属性名称;

    column 属性:生成表中 id 字段名称 -->

    <!-- Hibernate 要求实体类有一个属性唯一值,

    Hibernate 要求表中字段有一个属性唯一值 -->

    <id name="uid" column="uid">

    <!-- 设置数据库表 id 的增长策略,

    native:主键 id 值自动增长 -->

    <generator class="native"></generator>

    </id>

    <!-- (3)

    property 标签:配置其它属性和表中字段对应;

    name 属性:实体类属性名称;

    column 属性:生成表中字段名称 -->

    <property name="username" column="username"></property>

    <property name="password" column="password"></property>

    <property name="address" column="address"></property>

    </class>

       

    </hibernate-mapping>

       

       

       

       

       

       

       

    创建 Hibernate 的核心配置文件

       

       

    1、创建 XML 格式的配置文件

       

    核心配置文件的名称和位置是固定的

       

    位置:必须在 src

       

    名称:必须是 hibernate.cfg.xml

       

    「cfg,即 Configuration」

       

       

       

    2、在配置文件中引入 XML 约束

       

    hibernate-configuration-3.0.dtd

       

       

    hibernate.cfg.xml 中添加如下约束:

       

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

    <!DOCTYPE hibernate-configuration PUBLIC

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

    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

       

       

       

    3、在核心配置文件中进行相关配置

       

    第一部分:配置数据库信息(必须)

       

    第二部分:配置 Hibernate 信息(可选)

       

    第三部分:引入映射配置文件,把映射文件放到核心配置文件中(必须)

       

    注意:Hibernate 在操作过程中,只会加载核心配置文件,其它配置文件

    不会进行加载

       

       

    hibernate.cfg.xml:

       

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

    <!DOCTYPE hibernate-configuration PUBLIC

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

    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

    <!-- 根标签 -->

    <hibernate-configuration>

    <session-factory>

    <!-- 第一部分:配置数据库信息(必须) -->

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

    <!-- 或使用 jdbc:mysql:///hibernate_db 代替,省略 localhost -->

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

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

    <property name="hibernate.connection.password">8888</property>

    <!-- 第二部分:配置 Hibernate 信息(可选) -->

    <!-- 输出底层 sql 语句 -->

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

    <!-- 输出底层 sql 语句格式 -->

    <property name="hibernate.format_sql">true</property>

    <!-- Hibernate 帮助创建表,不是自动创建,而需要配置之后。

    update:如果已经有表,就更新,如果没有,就自动创建 -->

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

    <!-- 配置数据库方言,让 Hibernate 框架识别不同数据库自己特有的语句。

    如:在 MySQL 中实现分页的关键字 limit,只能在 MySQL 中使用,而

    Oracle 中实现分页的关键字则是 rownum -->

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

    <!-- 第三部分:引入映射配置文件,把映射配置文件放到核心配置文件(必须) -->

    <mapping resource="com/siwuxie095/entity/User.hbm.xml"/>

    </session-factory>

    </hibernate-configuration>

       

       

       

    注:hibernate.properties 在 projectetc 文件夹下

       

       

       

       

       

       

       

       

    测试:实现添加操作

       

       

    第一步:加载 Hibernate 核心配置文件

       

    第二步:创建 SessionFactory 对象

       

    第三步:使用 SessionFactory 创建 Session 对象

       

    第四步:开启事务

       

    第五步:编写具体逻辑:CRUD 操作

       

    第六步:提交事务

       

    第七步:关闭资源

       

       

    「注意:只有第五步是变化的」

       

       

    包名:com.siwuxie095.hibernatetest

    类名:HibernateDemo.java

       

       

    HibernateDemo.java:

       

    package com.siwuxie095.hibernatetest;

       

    import org.hibernate.Session;

    import org.hibernate.SessionFactory;

    import org.hibernate.Transaction;

    import org.hibernate.cfg.Configuration;

    import org.junit.Test;

       

    import com.siwuxie095.entity.User;

       

    public class HibernateDemo {

       

    //手动加上 @Test 以进行单元测试(将自动导入 JUnit 4

    // jar 包)

    //

    //选中方法名,右键->Run As->JUint Test

    @Test

    public void addTest(){

    //第一步:加载 Hibernate 核心配置文件

    //

    //因为核心配置文件的名称和位置是固定的,所以会到

    //src 下找到 hibernate.cfg.xml 放到 cfg 对象中

    Configuration cfg=new Configuration();

    cfg.configure();

    //第二步:创建 SessionFactory 对象

    //

    //读取核心配置文件的内容,创建 SessionFactory

    //在创建的过程中,会根据映射关系,在数据库中将

    //表创建出来

    //

    //调用 cfg buildSessionFactory() 方法,返回

    //值是 SessionFactory 类型,创建以接收

    SessionFactory sessionFactory=cfg.buildSessionFactory();

       

    //第三步:使用 SessionFactory 创建 Session 对象

    //

    //类似于 JDBC 中的连接 Connection

    //

    //调用 sessionFactory openSession() 方法,返

    //回值是 Session 类型,创建以接收

    Session session=sessionFactory.openSession();

       

    //第四步:开启事务

    //

    //调用 session beginTransaction() 方法,返回

    //值是 Transaction 类型,创建以接收

    Transaction tx=session.beginTransaction();

       

    //第五步:编写具体逻辑:CRUD 操作

    User user=new User();

    user.setUsername("小明");

    user.setPassword("8888");

    user.setAddress("中国");

    //调用 session save() 方法实现添加

    session.save(user);

    //第六步:提交事务

    tx.commit();

       

    //第七步:关闭资源

    session.close();

    sessionFactory.close();

       

    }

    }

       

       

    运行一览:

       

    1)控制台:

       

       

       

    2)数据库:

       

       

       

       

       

       

       

    工程结构目录一览:

       

       

       

       

       

       

       

       

       

       

       

       

       

    【made by siwuxie095】

  • 相关阅读:
    mysql慢查询
    linux查找文件
    ss安装教程
    node_module删除
    api的错误代码设计
    es6的Promise
    vue后台项目
    vue的main.js
    vue的过渡效果
    【Linux网络基础】网络拓扑、OSI层次模型、TCP/IP协议簇
  • 原文地址:https://www.cnblogs.com/siwuxie095/p/7281614.html
Copyright © 2011-2022 走看看