这里先做一个简单的入门,后面有详解

记住图解原理:


这里只是没有整合spring等项目使用的hibernate的使用详解。

一、Hibernate简介

1、Hibernate在开发中所处的位置

2、ORM映射

Object :面向对象领域的

Relational:关系数据库领域的

Mapping:映射

mapping:就是将object和Relational联系起来。

二、搭建开发环境

1、下载Hibernate的资源包

前往官网下载:http://hibernate.org/

创建一个java项目。命名hibernate01

2、准备Hibernate运行的必备jar包

前提准备:数据库的驱动jar包

hibernate的必须jar包

共11个jar包

其中如何添加到项目中,有两种方法,这里将其一。可以在项目中建立一个lib文件夹。然后右键 build path 之后 add puild path 即可。

3、建立hibernate配置文件,配置数据源信息

在classpath下(根路径),建立一个默认名称为hibernate.cfg.xml配置文件(许多开发项目中未必见到hibernate.cfg.xml这个名称的xml文件,后期做详解)

<?xml version="1.0" encoding="UTF-8"?>
<!-- 拷贝要引入的dtd约束。该dtd文件在hibernate的核心jar包的 org/hibernate/hibernate-configuration-3.0.dtd-->
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<!-- 配置一个Session的工厂。 负责生产Session对象
Session对象就相当于JDBC中的Connection和Statement的组合体-->
<session-factory>
<!-- 这些key value 的位置在:hibernate-distribution-3.6.10.Final\project\etc\hibernate.properties中定义着-->
<!-- 配置连接数据库的基本信息。细节:他们都是以hibernate开头的。hibernate写不写都行。 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/student_database</property>
<property name="connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<!-- 配置数据库的方言 -->
<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>
<!-- 自动生成ddl语句
SQL:DDL数据定义语言 DML数据操作语言 DQL数据查询语言 Transaction PL事务处理语言 DCL数据控制语言 Cursor CL指针控制语言
create-drop:创建表结构,只要SessionFactory工厂一结束,表结构没了
create:创建表结构,每次执行都重新创建
update:每次检查表结构的变化,如果不一致,更新表结构
validate:检查表结构
-->
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 请注意:配置映射关系 -->
<mapping resource="net/gbicc/domain/Student.hbm.xml" />
</session-factory>
</hibernate-configuration>

其中hibernate-distribution-3.6.10.Final是下载下来的hibernate压缩包解压缩后的目录。(注意这里的url后面的/student是数据库名称,下面我用的是student_database数据库做的案例。若要重复我的操作请注意这点)

基本数据源连接的配置要根据你安装的mysql 数据库,或者其它数据库的定义而进行相关的配置。如果还是不懂,请学习jdbc相关内容。

到这环境已经准备完毕。开始入门案例。

三、第一个入门案例(把学生信息保存到数据库)

1、建立数据模型(实体类)

前提:数据库已经创建表好表结构了。sql语句见下图

注意:要根据数据库的设计存储结构一一对应。


2、建立实体类和数据库表的对应关系

在实体类所在的包中,建立一个“类名.hbm.xml”名称(不是必须的后期详解)的映射文件。

3、编写保存学生信息的代码

然后运行发现抛出错误

注意运行需要用log4j.properties。因为hibernate需要此文件

原因:我们虽然写了mapping映射文件,我们并没有告诉hibernate,实体javabean和表的映射 ,hibernate不知道,如何让他知道呢?那就是将他们联系起来。

配置映射关系:就是将主配置文件和映射文件建立关系

 

<?xml version="1.0" encoding="UTF-8"?>
<!-- 拷贝要引入的dtd约束。该dtd文件在hibernate的核心jar包的 org/hibernate/hibernate-configuration-3.0.dtd-->
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<!-- 配置一个Session的工厂。 负责生产Session对象
Session对象就相当于JDBC中的Connection和Statement的组合体-->
<session-factory>
<!-- 这些key value 的位置在:hibernate-distribution-3.6.10.Final\project\etc\hibernate.properties中定义着-->
<!-- 配置连接数据库的基本信息。细节:他们都是以hibernate开头的。hibernate写不写都行。 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/student_database</property>
<property name="connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<!-- 配置数据库的方言 -->
<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>
<!-- 自动生成ddl语句
SQL:DDL数据定义语言 DML数据操作语言 DQL数据查询语言 Transaction PL事务处理语言 DCL数据控制语言 Cursor CL指针控制语言
create-drop:创建表结构,只要SessionFactory工厂一结束,表结构没了
create:创建表结构,每次执行都重新创建
update:每次检查表结构的变化,如果不一致,更新表结构
validate:检查表结构
-->
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 请注意:配置映射关系 -->
<mapping resource="net/gbicc/domain/Student.hbm.xml" />
</session-factory>
</hibernate-configuration>

然后再次执行结果成功了(数据库中对应的表有内容了)

4、案例的执行过程


其它问题详见下一章

Hibbernate详解一的更多相关文章

  1. Linq之旅:Linq入门详解(Linq to Objects)

    示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...

  2. 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)

    一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...

  3. EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解

    前言 我比较喜欢安静,大概和我喜欢研究和琢磨技术原因相关吧,刚好到了元旦节,这几天可以好好学习下EF Core,同时在项目当中用到EF Core,借此机会给予比较深入的理解,这里我们只讲解和EF 6. ...

  4. Java 字符串格式化详解

    Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...

  5. Android Notification 详解(一)——基本操作

    Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...

  6. Android Notification 详解——基本操作

    Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...

  7. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  8. Drawable实战解析:Android XML shape 标签使用详解(apk瘦身,减少内存好帮手)

    Android XML shape 标签使用详解   一个android开发者肯定懂得使用 xml 定义一个 Drawable,比如定义一个 rect 或者 circle 作为一个 View 的背景. ...

  9. Node.js npm 详解

    一.npm简介 安装npm请阅读我之前的文章Hello Node中npm安装那一部分,不过只介绍了linux平台,如果是其它平台,有前辈写了更加详细的介绍. npm的全称:Node Package M ...

随机推荐

  1. (转)NHibernate+MySql常见问题

    http://blog.51cto.com/4837471/1567675 版本: NHibernate :NHibernate 4.0.1GA MySql:MySql 5.0.1 常见问题一: “N ...

  2. 什么是 BULK INSERT

    MSDN的解释: 在 SQL Server 中以用户指定的格式将数据文件导入到数据库表或视图中. 语法: BULK INSERT [ database_name . [ schema_name ] . ...

  3. hdu4497-GCD and LCM-(欧拉筛+唯一分解定理+组合数)

    GCD and LCM Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total ...

  4. Failed to read schema document 'http://www.springframework.org/schema/beans/spring-beans.xsd'

    明明项目没错误,但application.xml就报了错误,这是什么问题呢? 问题在于我们找不到org/springframework/beans/spring-beans这个包,也就是我们的spri ...

  5. elasticsearch 测试

    https://www.yiibai.com/elasticsearch/elasticsearch-getting-start.html # curl -XPUT "http://loca ...

  6. pandas 读取大文件 read_table C-engine CParserError: Error tokenizing data

    解决办法: pd_data = pd.read_table(comment_file,header=None,encoding='utf-8', engine='python') 官网解析: engi ...

  7. spring注解之@Lazy

    今天主要从以下几方面来介绍一下@Lazy注解 @Lazy注解是什么 @Lazy注解怎么使用 1,@Lazy注解是什么   @Lazy注解用于标识bean是否需要延迟加载,源码如下: @Target({ ...

  8. day30 UDP协议

    本周安排 周二 socket编程 周三 粘包处理 周四 选课系统 并发编程 周五多道技术 多进程 周六 IPC 互斥锁 常用模块 os* 操作系统 多数是文件操作 os.path 处理文件路径 shu ...

  9. Java反射、动态加载(将java类名、方法、方法参数当做参数传递,执行方法)

    需求:将java类名.方法.方法参数当做参数传递,执行方法.可以用java的动态加载实现   反射的过程如下:     第一步:通过反射找到类并创建实例(classname为要实例化的类名,由pack ...

  10. Pandas操作数据库及保存csv

    数据的保存 import pandas as pd import numpy as np from pandas import Series col_db = [['one',1,2,3,4,np.n ...