初见Hibernate
来源:互联网 发布:海康威视 无网络视频 编辑:程序博客网 时间:2024/06/05 03:41
Hibernate相关
什么是Hibernate
Hibernate (开放源代码的对象关系映射框架)
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans
与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
基础概念
1.数据持久化?
数据持久化就是将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型的统称. 数据模型可以是任何数据结构或对象模型,存储模型可以是关系模型、XML、二进制流等。cmp和Hibernate只是对象模型到关系模型之间转换的不同实现。
简单的理解就是:原本数据在应用程序中出现后,程序关闭数据消失.我们为了将数据保存下来,保存的过程称之为数据持久化.
2.如何数据持久化?
数据持久化方式一般为将数据存储在文本文件或者数据库中。
Java实现方式为JDBC连接数据库,对数据进行操作或者通过IO流的形式存储在文本文件中。
3.JDBC?
JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序.
JDBC是基础的实现对数据库操作的方式,为什么会有Hibernate?因为Hibernate将对数据库的操作转换为对Java对象的操作,从而简化开发。通过修改一个“持久化”对象的属性从而修改数据库表中对应的记录数据。
4.ORM框架?
对象-关系映射(Object/Relation Mapping,简称ORM),是随着面向对象的软件开发方法发展而产生的。面向对象的开发方法是当今企业级应用开发环境中的主流开发方法,关系数据库是企业级应用环境中永久存放数据的主流数据存储系统。对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系,而在数据库中,关系数据无法直接表达多对多关联和继承关系。因此,对象-关系映射(ORM)系统一般以中间件的形式存在,主要实现程序对象到关系数据库数据的映射。
5.如果没有Hibernate如何编程?
对数据库操作进行CRUD?即增删改查
//1.加载驱动程序 Class.forName("com.mysql.jdbc.Driver"); //2.获得数据库的连接 Connection conn = DriverManager.getConnection(URL, NAME, PASSWORD); //3.通过数据库的连接操作数据库,实现增删改查 Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SQL语句"); //获得结果集
6.Hiberna大致实现?
创建POJO类
public class User { //实体类的属性和表的字段名称一一对应 private int id; private String UserName; private String Password; public User(){ } User(String UserName,String Password){ this.UserName=UserName; this.Password=Password; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUserName() { return UserName; } public void setUserName(String userName) { UserName = userName; } public String getPassword() { return Password; } public void setPassword(String password) { Password = password; } }
配置映射文件
xx.hbm.xml
,数据库配置hibernate.cfg.xml
User user=new User();//POJO类Configuration cfg = new Configuration().configure();//使用new Configuration().configure();来读取hibernate.cfg.xml配置文件SessionFactory sf= cfg.buildSessionFactory();//创建一个数据库对应一个SessionFactory//session是非线程安全,一般是一个请求一个session.session = sf.openSession();//手动开启事务(可以在hibernate.cfg.xml配置文件中配置自动开启事务)session.beginTransaction();/*保存数据,此处的数据是保存对象,这就是hibernate操作对象的好处,我们不用写那么多的JDBC代码,只要利用session操作对象,至于hibernat如何存在对象,这不需要我们去关心它,* 这些都有hibernate来完成。我们只要将对象创建完后,交给hibernate就可以了。 */session.save(user);//事物类型session.getTransaction().commit();//提交请求
实现Hibern框架编程
配置环境
1.下载Hibernate:
http://hibernate.org/orm/downloads/
点击绿色按钮,在跳转页面后自动下载
2.添加jar包:
Hibernate所需包:
依赖路径:
hibernate-release-xxxx.Final\lib\required
JDBC-Connection所需包
https://dev.mysql.com/downloads/connector/
步骤一、
步骤二、
3.拷贝并配置文件hibernate.cfg.xml
, log4j.properties
依赖路径:hibernate-release-xxxx.Final\project\etc
<!-- ~ Hibernate, Relational Persistence for Idiomatic Java ~ ~ License: GNU Lesser General Public License (LGPL), version 2.1 or later. ~ See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. --><!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 name="foo"> <!-- 配置MySQl数据库的连接参数 --> <property name="hibernate.dialect">org.hibernate.dialect.MySQL57Dialect</property> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/demo</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">root</property> <!--<property name="show_sql">true</property>--><!-- <mapping resource="org/hibernate/test/legacy/Simple.hbm.xml"/> <class-cache class="org.hibernate.test.legacy.Simple" region="Simple" usage="read-write"/>--> <mapping resource="com/BoomMan/Struct/User.hbm.xml"/> </session-factory></hibernate-configuration>
4.数据库建表,POJO类创建
/** * Creat By BoomMan * Time : 2017.05.03 * users表所对应的实体类 */public class User { //实体类的属性和表的字段名称一一对应 private int id; private String UserName; private String Password; public User(){ } User(String UserName,String Password){ this.UserName=UserName; this.Password=Password; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUserName() { return UserName; } public void setUserName(String userName) { UserName = userName; } public String getPassword() { return Password; } public void setPassword(String password) { Password = password; }}
5.拷贝并配置映射文件*.hbm.xml
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><!-- <hibernate-mapping>一般不去配置,采用默认即可。 default-cascade="none":默认的级联风格,表与表联动。 default-lazy="true":默认延迟加载 --><hibernate-mapping> <!-- <class>:使用class元素定义一个持久化类。 name="cn.javass.user.vo.UserModel":持久化类的java全限定名; table="tbl_user":对应数据库表名; mutable="true":默认为true,设置为false时则不可以被应用程序更新或删除; dynamic-insert="false":默认为false,动态修改那些有改变过的字段,而不用修改所有字段; dynamic-update="false":默认为false,动态插入非空值字段; select-before-update="false":默认为false,在修改之前先做一次查询,与用户的值进行对比,有变化都会真正更新; optimistic-lock="version":默认为version(检查version/timestamp字段),取值:all(检查全部字段)、dirty(只检查修改过的字段)、 none(不使用乐观锁定),此参数主要用来处理并发,每条值都有固定且唯一的版本,版本为最新时才能执行操作; --> <class name="com.BoomMan.Struct.User" table="user" dynamic-insert="true" dynamic-update="true" optimistic-lock="version"> <!-- <id>:定义了该属性到数据库表主键字段的映射。 name="userId":标识属性的名字; column="userId":表主键字段的名字,如果不填写与name一样; --> <id name="id" column="id"> <!-- <generator>:指定主键由什么生成,推荐使用uuid,assigned指用户手工填入。 --> <generator class="native"/> </id> <!-- <version/>:使用版本控制来处理并发,要开启optimistic-lock="version"和dynamic-update="true"。 name="version":持久化类的属性名,column="version":指定持有版本号的字段名; --><!-- 这里应该用序列化和反序列化<version name="id" column="version"/>--> <!-- <property>:为类定义一个持久化的javaBean风格的属性。 name="name":标识属性的名字,以小写字母开头; column="name":表主键字段的名字,如果不填写与name一样; update="true"/insert="true":默认为true,表示可以被更新或插入; --> <property name="userName" column="UserName"/> <property name="password" column="Password"/> <!-- 组件映射:把多个属性打包在一起当一个属性使用,用来把类的粒度变小。 <component name="属性,这里指对象"> <property name="name1"></property> <property name="name2"></property> </component> --> <!-- <join>:一个对象映射多个表,该元素必须放在所有<property>之后。 <join table="tbl_test:子表名"> <key column="uuid:子表主键"></key> <property name="name1:对象属性" column="name:子表字段"></property> </join> --> </class></hibernate-mapping>
6.测试运行
public static void main(String[] args) { Configuration cfg = null; SessionFactory sf = null; Session session = null; User user=new User(); user.setUserName("BoomMan"); user.setPassword("000"); /* * org.hibernate.cfg.Configuration类的作用: * 读取hibernate配置文件(hibernate.cfg.xml或hiberante.properties)的. * new Configuration()默认是读取hibernate.properties * 所以使用new Configuration().configure();来读取hibernate.cfg.xml配置文件 */ cfg = new Configuration().configure(); /* * 创建SessionFactory * 一个数据库对应一个SessionFactory * SessionFactory是线线程安全的。 */ sf = cfg.buildSessionFactory(); try { //创建session //此处的session并不是web中的session //session只有在用时,才建立concation,session还管理缓存。 //session用完后,必须关闭。 //session是非线程安全,一般是一个请求一个session. session = sf.openSession(); //手动开启事务(可以在hibernate.cfg.xml配置文件中配置自动开启事务) session.beginTransaction(); /* * 保存数据,此处的数据是保存对象,这就是hibernate操作对象的好处, * 我们不用写那么多的JDBC代码,只要利用session操作对象,至于hibernat如何存在对象,这不需要我们去关心它, * 这些都有hibernate来完成。我们只要将对象创建完后,交给hibernate就可以了。 */ session.save(user); session.getTransaction().commit(); } catch (HibernateException e) { e.printStackTrace(); //回滚事务 session.getTransaction().rollback(); } finally { //关闭session session.close(); sf.close(); } }
- 初见Hibernate
- Hibernate—初见
- 初见
- 初见
- 初见
- 初见
- 初见
- 初见 Catalyst
- Hadoop初见
- 初见端倪
- 初见面
- 初见python
- usb初见
- 初见CSDN
- 初见gdb
- Gstreamer初见
- 初见Android
- 初见数据库
- SQL语句的优化
- 安卓7.0 加载libsqlite.so文件失败
- Kafka-[1]-Documentation-概述
- 某场小考(1)
- 关于使用sklearn进行数据预处理 —— 归一化/标准化/正则化
- 初见Hibernate
- 《Spring in action》——学习总结(一)
- 简明Pyhton教程余下基础内容
- heatmap.js调用百度地图api做热力图
- Java8新特性接口的增强之default方法
- 表单处理的方案与注意事项(servlet)
- c语言-函数(1)
- java--jspsmartupload组件抛出异常总结
- nginx stream模块初探