Hibernate入门基础
来源:互联网 发布:lr软件怎么使用 编辑:程序博客网 时间:2024/06/15 12:50
**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 //操作数据库时,若表不存在,则创建表;若表存在,则正常操作;若要增加表中新的字段,则会增加新的字段且不改变表结构。
* 引入映射配置文件(一定要注意,要引入映射文件,框架需要加载映射文件)
* <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. 具体的代码如下
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- Hibernate入门 - 基础配置
- 一、Hibernate基础入门
- Hibernate入门基础
- Hibernate入门 - 基础配置
- Hibernate基础--入门
- Hibernate框架基础入门
- Hibernate的基础入门
- Hibernate基础入门
- hibernate的基础入门
- Hibernate入门基础
- hibernate的基础入门
- 【codevs 2273】扬帆远洋大战牧师妹酱
- 1.SQL SERVER笔记——java链接SQL SERVER
- yum-update.sh
- PAT 乙级练习题1019. 数字黑洞 (20)
- Django-uploadfile(上传图片为例)
- Hibernate入门基础
- Java 并发编程(二)线程状态跃迁
- 147. Insertion Sort List。
- 优化图片的加载
- freeCodeCamp第一天
- c++基础之以文本形式的存储
- HDU 1166
- 2.SQL SERVER笔记——SQL SERVER系统概念
- NYOJ-ACM-A+B Problem II