Hibernate知识总结(一)
一、ORM
ORM的全称是Object/Relation Mapping,即对象/关系映射,可以将其理解成一种规范,它概述了这类框架的基本特征:完成面向对象的编程语言到关系数据库的映射。可以把ORM看作应用程序和数据库的桥梁。
ORM基本映射方式
1、数据表映射实体类(持久化类);
2、数据表中的行映射对象;
3、数据表中的字段映射对象的属性。
基本上所有的ORM工具大致都遵循相同的映射思路。
二、Hibernate
Hibernate是一款轻量级的持久层框架,它完成了对象模型和基于SQL的关系模型的映射关系,使得开发者能够以面向对象的方式开发应用程序,它还提供数据处理的方法,可以大幅度减少开发人员使用SQL和JDBC处理数据的时间。
Hibernate初步使用
下载Hibernate(此步骤略过),解压该文件;
使用IDE新建普通java项目(本人使用idea),在项目中引入使用Hibernate所必须的jar包,即引入required文件夹中的jar包;另外此处使用JDBC连接,需要额外引入mysql-connector的jar包
现在使用一个简单的小例子,实现Hibernate的初步使用。
注:此处使用的是Hibernate的注解来创建数据表,不提及xml配置文件建表方式。
创建持久化类User,该类和一般的JavaBean并没有什么区别;
User类包含id、userName、age属性,User类的代码如下:
package com.yjry.note;
public class User {
private Integer id;
private String userName;
private Integer age;
//重写toString方法,便于显示数据
@Override
public String toString() {
return "User{" +
"id=" + id +
", userName='" + userName + '\'' +
", age=" + age +
'}';
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
为该类添加Hibernate注解,添加注解后代码如下:
package com.yjry.note; import javax.persistence.*; @Entity
@Table(name = "t_user")
public class User {
@Id
@Column(nullable = false)
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(name = "user_name", length = 30)
private String userName;
private Integer age;
//重写toString方法,便于显示数据
@Override
public String toString() {
return "User{" +
"id=" + id +
", userName='" + userName + '\'' +
", age=" + age +
'}';
} public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getUserName() {
return userName;
} public void setUserName(String userName) {
this.userName = userName;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
}
}
下面解释下各个注解的意义:
@Entity注解声明该类是一个Hibernate的持久化类;
@Table注解指定该类映射的数据表,此处指定该类映射的数据表为t_user表;
@Id用于指定该类的标识属性(可以唯一表示该对象的属性),标识属性通常映射到数据表的主键列;
@GeneratedValue用于指定主键生成策略,其中strategy属性指定了主键生成策略为IDENTITY,对于MySQL数据库来说,主键自增长。
接下来编写Hibernate的核心配置文件hibernate.cfg.xml(该文件名为Hibernate加载的默认文件名),配置文件代码如下:
<!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://localhost:3306/test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property> <!--是否打印sql语句-->
<property name="hibernate.show_sql">true</property>
<!--打印出来的sql语句是否格式化-->
<property name="hibernate.format_sql">true</property> <!--建表策略,建议使用update-->
<property name="hibernate.hbm2ddl.auto">update</property>
<!--指定数据库方言-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!--告诉hibernate映射文件所在位置-->
<mapping class="com.yjry.note.User"/>
</session-factory>
</hibernate-configuration>
建表策略
hibernate.hbm2ddl.auto属性可以为validate、update、create、create-drop。
validate:每次创建SessionFactory时,若数据库中没有与持久化类对应的数据表,或者数据表与持久化类不一致,则抛出异常;
注:判断不一致的条件为:数据表中缺少持久化类的属性对应的字段,也就是说,若持久化类对应的数据表含有多余的字段,不会影响validate检查,即程序不会抛出异常。
update:每次创建SessionFactory时,若数据库中没有与持久化类对应的数据表,则自动建表;若数据库中存在对应的表,则保留已有的数据表和数据,仅更新或插入数据;
create:每次创建SessionFactory时,都会自动建表,若之前存在数据表,则原表保留的数据会全部丢失;
create-drop:每次创建SessionFactory时,自动建表,SessionFactory关闭时,自动删表。
数据库方言
Hibernate底层依然使用SQL语句来执行数据库操作,然而各个数据库在SQL语法上存在一些差异,因此Hibernate需要根据数据库来识别这些差异,此时就要指定hibernate.dialect,这里使用MySQL数据库方言,告诉Hibernate使用MySQL的方式执行SQL语句。
创建测试类,完成数据表的创建以及数据的插入操作。代码如下:
package com.yjry.test; import com.yjry.note.User;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; public class UserTest {
public static void main(String[] args) {
/**
* 加载Hibernate配置文件
* 不带参数的Configuration方法,默认加载hibernate.cfg.xml文件
* 若传入test.xml作为参数,则加载test.xml文件
*/
Configuration configuration = new Configuration().configure();
//创建SessionFactory实例,创建该实例后,数据表已经创建完毕
SessionFactory sessionFactory = configuration.buildSessionFactory();
//创建Session实例
Session session = sessionFactory.openSession();
//开启事务
Transaction transaction = session.beginTransaction();
//创建User对象,并设置属性
User user = new User();
user.setUserName("张三");
user.setAge(20);
//执行session的save方法,保存数据,数据表待插入该数据
session.save(user);
//提交事务,数据插入到数据表
transaction.commit();
//关闭资源
session.close();
sessionFactory.close();
}
}
执行该代码,会发现MySQL数据库中多了一张t_user表,该表包含id、age、user_name三个字段,并且刚才创建的User对象数据已经插入到数据表中。

Hibernate知识总结(一)的更多相关文章
- hibernate 知识梳理
一.hibernate背景介绍: 作者: Gavin King 分hibernate ORM(for relation db),OGM(for nosql db),hearch,validator,t ...
- HIBERNATE知识复习记录1-连接及常用方法
要去面试了,复习一下HIBERNATE的相关知识吧,原来边看视频边写的代码如下,已经分不清先后次序了,大致看一看吧. 先看下总的配置文件hibernate.cfg.xml: <?xml vers ...
- 【Hibernate那点事儿】—— Hibernate知识总结
前言: 上一篇简单的讲解了下Hibernate的基础知识.这里对Hibernate比较重要的一些知识点,进行总结和归纳. 手码不易,转载请注明!——xingoo 总结的知识点: 1 关于hiberna ...
- Hibernate知识总结(一)——Hibernate原理概述
一.Hibernate是什么: 它是一个持久化框架,它对JDBC进行了轻量级的封装,简化对数据库的操作,提高开发效率.和另一个持久化框架MyBatis一样,他们操作数据库都是通过一个session对象 ...
- Hibernate 知识提高
主键生成策略有: UUID,increment.Hilo.assigned:对数据库无依赖 identity:依赖Mysql或sql server,主键值不由hibernate维护 sequence: ...
- HIBERNATE知识复习记录4-HQL和QBC
Hibernate中共提供了三种检索方式:HQL(Hibernate Query Language).QBC.QBE(Query By Example). HQL 是Hibernate Query L ...
- HIBERNATE知识复习记录3-关联关系
先上一张图,关于几种关系映射: 抄一段解释: 基本映射是对一个实体进行映射,关联映射就是处理多个实体之间的关系,将关联关系映射到数据库中,所谓的关联关系在对象模型中有一个或多个引用.关联关系分为上述七 ...
- HIBERNATE知识复习记录2-继承关系
发现了一篇和我类似的学习尚硅谷视频写的文章,内容如下,比我说的详细全面,可以看一下: [原创]java WEB学习笔记87:Hibernate学习之路-- -映射 继承关系(subclass , jo ...
- Hibernate知识梳理
一.SessionFactory接口 是单个数据库映射关系(ORM)经过编译后的内存镜像.SessionFactory(的实例)作为应用中的一个全局对象(工厂),可以随处打开/创建一个session, ...
随机推荐
- xp密钥-资源分享
xp-密钥:QC986-27D34-6M3TY-JJXP9-TBGMD ftp-资源地址: ftp://10.10.31.2/?tdsourcetag=s_pctim_aiomsg
- Unity正交模式摄像机与屏幕适配的方法
public class CameraAuto : MonoBehaviour { float fDefaultRatio = 720.0f / 1280.0f;//预先设定屏幕大小1280*720 ...
- centos-0 基础
netstat -nap #会列出所有正在使用的端口及关联的进程/应用kill -9 1777 #杀掉编号为1777的进程(请根据实际情况输入) http://www.cnblogs.c ...
- mysql 索引及索引创建原则
是什么 索引用于快速的查询某些特殊列的某些行.如果没有索引, MySQL 必须从第一行开始,然后通过搜索整个表来查询有关的行.表越大,查询的成本越大.如果表有了索引的话,那么 MySQL 可以很快的确 ...
- 修改Tomcat控制台标题
1.在tomcat的bin目录下新建文件setenv.bat 2.重启tomcat即可
- 使用gcc命令编译多个文件
使用g++命令直接一次性编译多个文件 这里以简单的HelloWorld程序为例,假设我们一共有三个文件:main.cpp,HelloWorld.cpp和HelloWorld.h. 其中HelloWor ...
- 对DOM,SAX,JDOM,DOM4J四种方法解析XML文件的分析
1.DOM 与平台无关的官方解析方式 DOM是一次性把xml文件加载到内存中,形成一个节点树 对内存有要求 2.SAX java提供的基于事件驱动的解析方式 每次遇到一个标签,会触发相应的事件方法 3 ...
- “天龙八步”细说浏览器输入URL后发生了什么
本文摘要: 1.DNS域名解析: 2.建立TCP连接: 3.发送HTTP请求: 4.服务器处理请求: 5.返回响应结果: 6.关闭TCP连接: 7.浏览器解析HTML: 8.浏览器布局渲染: 总结 输 ...
- [记录]MySQL 查询无法导出到文件
很多时候我们需要将数据导出到 xls文件, 然后交给数据分析师分析. 而这个查询数据+导出的动作,理应使用一个有只读权限的用户使用. 但查询某表时: select * from table ,此用户可 ...
- C语言错题集
1.输入两个int型数a.b,求a/b的商c,不必考虑b为0的情况,输出c(保留两位小数) include<stdio.h> int main() { int a,b; float c; ...