JavaWeb(框架--Hibernate):----配置

来源:互联网 发布:php属于前端还是后端 编辑:程序博客网 时间:2024/05/22 02:16

一.概念初识
  hibernate是一个开源的对象关系映射框架,实现了对JDBC的轻量级封装,将pojo(javaBean)与数据库表建立映射关系,是一个全自动的ORM框架,Hibernate在底层自动生成sql语句,能够实现数据的持久化
  ORM:Object Relational Mapping.对象关系映射.意味着将对象和与数据库中的表建立一种映射关系,操作对象就可以操作这个表.
二.资源下载
  Hibernate资源包地址:http://hibernate.org/orm/. 将下载后的资源,解压后的得到Hibernate的工程目录
  这里写图片描述
  lib包是需要使用的工具包,其中required包是必须的包文件,其它的jar包可以根据需要进行使用.
  documentation包是相关文档说明.
  project是对应Hibernate提供的案例工程
三.案例演示
   在本文中,只作最基本的案例演示.开发环境:win+idea
  第一步:创建WEB工程,并根据需要导入相关的包,例如数据库驱动包,日志记录包,核心包(必备),C3p0连接池等.
  第二步:创建数据库和表文件
  这里写图片描述
  第三步:根据建立的表文件中的字段建立实体类,(实体类的名称应和表中的字段最好保持一致)
注意:实体类需要提供无参构造和对相应的set/get方法.这是持久化对象的编写规则.
这里写图片描述
  第四步:根据实体类生成对应的映射文件.
在本案例中,使用的是XML的文件的方式进行关系映射,暂不使用注解.idea能够有效的支持Xml的映射配置.
Myeclipse需要进行相关配置文件设置,才能出现标签代码提示.
idea和Myeclipse均能够自动生成XML文件.
映射文件命名规则 类名.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"><hibernate-mapping>    <!-- ORM:Object Relational Mapping,将实体类O和数据库的表R 建立映射关系 -->    <class name="com.itheima.hibernate.domain.Customer" table="cst_customer">        <!-- 类中的属性与表中的主键对应 -->        <id name="cust_id" column="cust_id">            <generator class="native"/>        </id>        <!-- 类中的属性与表中的字段对应 -->        <property name="cust_name" column="cust_name"/>        <property name="cust_source" column="cust_source"/>        <property name="cust_industry" column="cust_industry"/>        <property name="cust_level" column="cust_level"/>        <property name="cust_phone" column="cust_phone"/>        <property name="cust_mobile" column="cust_mobile"/>    </class></hibernate-mapping>

   第五步:创建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>        <property name="hibernate.connection.url">jdbc:mysql:///hibernate_day01</property>        <!-- 用户名 -->        <property name="hibernate.connection.username">****</property>        <!-- 密码 -->        <property name="hibernate.connection.password">****</property>        <!-- 数据库的方言:根据底层的数据库生成不同的SQL -->        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>        <!-- 配置显示SQL -->        <property name="hibernate.show_sql">true</property>        <!-- 配置格式化SQL -->        <property name="hibernate.format_sql">true</property>        <!-- 配置hbm2ddl -->        <property name="hibernate.hbm2ddl.auto">update</property>        <!-- 加载映射文件 -->        <mapping resource="com/itheima/hibernate/domain/Customer.hbm.xml"/>    </session-factory></hibernate-configuration>

第六步.编写测试方法

public class HibernateDemo1 {    @Test    /**     * 保存操作     */    public void demo1(){        // 加载Hibernate的核心配置文件.        Configuration configuration = new Configuration().configure();        // 创建一个SessionFactory的对象.        SessionFactory sessionFactory = configuration.buildSessionFactory();        // 创建Session(相当于JDBC中的Connection)        Session session = sessionFactory.openSession();        // 开启事务:        Transaction transaction = session.beginTransaction();        // 完成操作:        Customer customer = new Customer();        customer.setCust_name("未来");        session.save(customer);        // 提交事务        transaction.commit();        // 释放资源        session.close();    }}

执行完测试方法之后,数据库中成功的添加了一条数据,测试成功!!
这里写图片描述

总结

在Hibernate的配置过程中,需要注意的关键点有两个,一个是类的映射文件,它能够将实体类和数据表成功的对应起来,一个是Hibernate的核心配置文件,它能配置Hibernate所需的所有信息.

1 0
原创粉丝点击