Hibernate入门基础

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_26022579/article/details/78089853

**Hibernate框架的概述**

1. Hibernate框架的概述
* Hibernate是一个开放源代码的对象关系映射(ORM)框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 
* Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用。
* Hibernate是轻量级JavaEE应用的持久层解决方案,是一个关系数据库ORM框架

2. Hibernate是一个持久层的ORM框架!


**什么是ORM(对象关系映射)**

1. ORM映射:Object Relational Mapping
* O:面向对象领域的Object(JavaBean对象)
* R:关系数据库领域的Relational(表的结构)
* M:映射Mapping(XML的配置文件)
2. 简单一句话:Hibernate使程序员通过操作对象的方式来操作数据库表记录


**Hibernate优点**

1. 优点
* Hibernate对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码
* Hibernate是一个基于jdbc的主流持久化框架,是一个优秀的orm实现,它很大程度的简化了dao层编码工作
* Hibernate的性能非常好,因为它是一个轻量级框架。映射的灵活性很出色。它支持很多关系型数据库,从一对一到多对多的各种复杂关系


Hibernate框架的快速入门

这里拿我写的一个客户关系管理系统作为例子

**第一步:下载Hibernate5的运行环境**

1. 下载相应的jar包等
 http://sourceforge.net/projects/hibernate/files/hibernate-orm/5.0.7.Final/hibernate-release-5.0.7.Final.zip/download

2. 解压后对目录结构可以自己去了解,这里不再赘述



**第二步:创建表结构**

1. 建表语句如下
Create database hibernate;
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的开发环境**

1. 创建WEB工程,引入Hibernate开发所需要的jar包
* MySQL的驱动jar包
* Hibernate开发需要的jar包(资料/hibernate-release-5.0.7.Final/lib/required/所有jar包)
* 日志jar包(资料/jar包/log4j/所有jar包)

----------

**第四步:编写JavaBean实体类**

1. Customer类的代码如下:
----------


**第五步:创建类与表结构的映射**

1. 在JavaBean所在的包下创建映射的配置文件
* 默认的命名规则为:实体类名.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">

2. 如果不能上网,编写配置文件是没有提示的,需要自己来配置
* 先复制http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd --> window --> preferences --> 搜索xml --> 选择xml catalog --> 点击add --> 现在URI --> 粘贴复制的地址 --> 选择location,选择本地的DTD的路径

3. 编写映射的配置文件

<?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属性,JavaBean的属性
			见到column属性,是表结构的字段
		-->
		<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核心的配置文件**

1. 在src目录下,创建名称为hibernate.cfg.xml的配置文件
2. 在XML中引入DTD约束
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

3. 打开:资料/hibernate-release-5.0.7.Final/project/etc/hibernate.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    //控制台打印sql语句
#hibernate.format_sql true  //格式化sql预计
#hibernate.hbm2ddl.auto update  //操作数据库时,若表不存在,则创建表;若表存在,则正常操作;若要增加表中新的字段,则会增加新的字段且不改变表结构。

扫描二维码关注公众号,回复: 4452863 查看本文章


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

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">root</property>
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
				
		<mapping resource="com/itheima/domain/Customer.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

----------

**第七步:编写Hibernate入门代码**
1. 具体的代码如下

猜你喜欢

转载自blog.csdn.net/qq_26022579/article/details/78089853