Hibernate 初级入门

一、下载 Hibernate 的运行环境

http://hibernate.org/orm/releases/

二、创建表结构

Create database hibernate_day01;
    Use hibernate_day01;
    CREATE TABLE `cst_customer` (
      `cust_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '客户编号(主键)',
      `cust_name` varchar(32) NOT NULL COMMENT '客户名称(公司名称)',
      `cust_user_id` bigint(32) DEFAULT NULL COMMENT '负责人id',
      `cust_create_id` bigint(32) DEFAULT NULL COMMENT '创建人id',
      `cust_source` varchar(32) DEFAULT NULL COMMENT '客户信息来源',
      `cust_industry` varchar(32) DEFAULT NULL COMMENT '客户所属行业',
      `cust_level` varchar(32) DEFAULT NULL COMMENT '客户级别',
      `cust_linkman` varchar(64) DEFAULT NULL COMMENT '联系人',
      `cust_phone` varchar(64) DEFAULT NULL COMMENT '固定电话',
      `cust_mobile` varchar(16) DEFAULT NULL COMMENT '移动电话',
      PRIMARY KEY (`cust_id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=94 DEFAULT CHARSET=utf8;

三、搭建 Hibernate 的开发环境

创建 WEB 工程,引入 Hibernate 开发所需要的 jar包

* MySQL 的驱动jar包

* Hibernate 开发需要的jar包(\hibernate-release-5.0.12.Final\hibernate-release-5.0.12.Final\lib\required 所有jar包)

* 日志jar包( \hibernate-release-5.0.12.Final\hibernate-release-5.0.12.Final\lib\optional\ehcache 所有jar包)

四、编写 JavaBean 实体类(Customer 类)

   public class Customer {
        private Long cust_id;
        private String cust_name;
        private Long cust_user_id;
        private Long cust_create_id;
        private String cust_source;
        private String cust_industry;
        private String cust_level;
        private String cust_linkman;
        private String cust_phone;
        private String cust_mobile;
        // 省略get和set方法
    }

五、创建类与表结构的映射

5.1 在 JavaBean 所在的包下创建映射的配置文件

* 默认的命名规则为:实体类名.hbm.xml (Customer.hbm.xml)
  * 在xml配置文件中引入约束(引入的是hibernate3.0的dtd约束,不要引入4的约束)
        <!DOCTYPE hibernate-mapping PUBLIC 
            "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
            "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

5.2 编写映射的配置文件

<?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>
        <class name="com.itheima.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_user_id" column="cust_user_id"/>
            <property name="cust_create_id" column="cust_create_id"/>
            <property name="cust_source" column="cust_source"/>
            <property name="cust_industry" column="cust_industry"/>
            <property name="cust_level" column="cust_level"/>
            <property name="cust_linkman" column="cust_linkman"/>
            <property name="cust_phone" column="cust_phone"/>
            <property name="cust_mobile" column="cust_mobile"/>
        </class>
    </hibernate-mapping>
六、编写 Hibernate 核心的配置文件

6.1. 在 src 目录下,创建名称为 hibernate.cfg.xml 的配置文件

6.2. 在 XML 中引入 DTD 约束
    <!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

6.3. 打开: \hibernate-release-5.0.12.Final\hibernate-release-5.0.12.Final\project\etchibernate.properties,可以查看具体的配置信息 
    * 必须配置的4大参数                 
        #hibernate.connection.driver_class com.mysql.jdbc.Driver
        #hibernate.connection.url jdbc:mysql:///test
        #hibernate.connection.username gavin
        #hibernate.connection.password

    * 数据库的方言(必须配置的)
        #hibernate.dialect org.hibernate.dialect.MySQLDialect

    * 可选的配置
        #hibernate.show_sql true
        #hibernate.format_sql true
        #hibernate.hbm2ddl.auto update

    * 引入映射配置文件(一定要注意,要引入映射文件,框架需要加载映射文件)
        * <mapping resource="com/itheima/domain/Customer.hbm.xml"/>             

6.4. 具体的配置如下
    <?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">root</property>
            <property name="hibernate.connection.password">root1234</property>
            <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>


            <mapping resource="com/itheima/domain/Customer.hbm.xml"/>
        </session-factory>
    </hibernate-configuration>
七、编写 Hibernate 入门代码

package com.test.demo1;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test;

import com.test.daomain.Customer;

public class TestDemo1 {
	@Test
	public void testSave() {
		/**
		 * 1. 加载配置文件
		 * 2. 创建 sessionFactory 对象,生产 session
		 * 3. 创建session 对象
		 * 4. 开启事务
		 * 5. 编写保存的代码
		 * 6. 提交事务
		 * 7. 释放资源
		 */
		
		// 加载配置文件
		Configuration config = new Configuration(); 
		config.configure();
		// 创建 sessionFactory 对象 
		SessionFactory factory = config.buildSessionFactory();
		// 创建session 对象
		Session session = factory.openSession();
		// 开启事务
		Transaction tr = session.beginTransaction();
		
		// 编写保存代码
		Customer c = new Customer();
		c.setCust_name("测试123");
		c.setCust_level("123");
		c.setCust_phone("123456");
		
		session.save(c);
		// 提交事务
		tr.commit();
		// 释放资源
		session.close();
		factory.close();
	}
}

八、总结

1. 下载Hibernate框架的开发包
2. 编写数据库和表结构
3. 创建WEB的项目,导入了开发的jar包
    * MySQL驱动包、Hibernate开发的必须要有的jar包、日志的jar包
4. 编写JavaBean,以后不使用基本数据类型,使用包装类
5. 编写映射的配置文件(核心),先导入开发的约束,里面正常配置标签
6. 编写hibernate的核心的配置文件,里面的内容是固定的
7. 编写代码,使用的类和方法


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值