一 Hibernate入门
Hibernate环境搭建
Hibernate的API
Hibernate的CRUD
EE三层结构:
- web层
- 业务逻辑层
- 持久层 jdbc,DBUTils,Hibernate
Hibernate简介:
一个开源的对象关系映射框架,对JDBC进行了轻量级封装,将pojo与数据库表建立映射关系,是一个全自动的ORM(Object Relation Mapping,对象关系映射,通过操作对象操作表)框架,可以自动生成sql语句,自动执行。
可以根据映射自动建表
HIbernate配置
Hibernate Configuration:Customer.hbm.xml
class标签:建立类与表的映射关系
属性:
- name: 类的全路径
- table:表名(类名和表名一致,table可省略)
- catalog:数据库名,可不填
id标签:建立类中的属性和表中主键对应关系
- name:类中属性
- column:表中字段(类中属性和表中字段一致,可省略该项)
- length:长度
- type:类型
property标签:普通属性和表中字段对应关系
- name:类中属性
- column:表中字段
- length:长度
- type:类型
- not-null:设置非空
- unique:设置唯一,默认false
Hibernate核心配置:
- 属性文件的方式 hibernate.properties(手动编写代码加载映射文件)
- xml文件的方式 hibernate.cfg.xml
必须配置:
- 连接数据库的基本参数:
- 驱动类
- url
- 用户名
- 密码
- 方言
可选配置:
- 显示sql:<property name="hibernate.show_sql">true</property>
- 格式化sql:<property name="hibernate.format_sql">true</property>
- 自动建表:<property name="hibernate.hbm2ddl.auto">update</property>
- none:不使用Hibernate的自动建表
- create:如果数据库已经有表,会删除原有表重新闯进啊
- create-drop:删除原有表创建新表,使用完后删除表。
- update:使用原来的表,在原来的表的上更新数据。如果没有表,创建新表(更新表结构)。
- validate: 如果没有表,不会创建表。只会用数据库中原有表(校验数据库表结构,自带校验功能)
- 映射文件的引入:<mapping resource="com/Hidemo1/Customer.hbm.xml"/>
编写测试类:
Hibernate的核心API:
Configuration类:
Hibernate的配置对象,以及对它进行启动。定位映射文档,读取配置,创建SessionFactory对象。
作用:加载核心配置文件,加载映射文件
SessionFactory接口:
负责初始化Hibernate,创建Session对象,用到了工厂模式。
作用:内部维护了Hibernate连接池和Hibernate的二级缓存(不讲,一般用Redis替换)。线程安全的,一个项目创建一个对象就可以。
配置成c3p0连接池(了解):
抽取工具类:
工具类测试:
Hibernate的核心对象:Session
类似连接对象Connection,负责执行被持久化对象的CRUD操作,是与数据库交互的桥梁。
由于是非线程安全对象,所以不能定义成全局的,需要定义在方法内部,否则有线程安全问题。
Session中的API:
保存:Serializable save(obj)
查询:T get(Class c ,Serializable id) , T load(Class c ,Serializable id)
- get采用的是立即加载,执行到这一行代码的时候就马上发送sql语句查询。
- get查询后返回的是对象本身。
- get查询找不到对象返回空
- load采用的是延迟加载(懒加载),执行到这行代码的时候,不会发送sql语句,当使用到这个对象的时候才会发送sql语句.
- load返回的是代理对象(非java动态代理,而是javasist技术产生的代理对象)
- load查询找不到对象返回ObjectNotFoundException
修改: void update(obj)
//直接创建对象进行修改,没有被set的属性会被置为null,不推荐
//先查询再修改(推荐方式)
删除:void delete(obj)
//直接创建对象进行删除
//先查询再删除(推荐方式,Hibernate下面有个级联删除,前提 是先查询再删除)
保存或更新:void saveOrUpdate(obj)
查询所有:
//接收HQL,Hibernate Query Language 面向对象的查询语言
Query query = session.createQuery("from Customer");
//接收sql
SQLQuery query2 = session.createSQLQuery("select * from cst_customer");
代码:
package com.Hidemo1; import java.util.Arrays;
import java.util.List; import org.hibernate.Query;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test; import com.HiUtils.HibernateUtils;
/**
* Hibernate入门
*
*/
public class HibernateDemo1 { @Test
//保存客户的需求
public void demo1(){
//1 加载核心配置文件
Configuration configuration = new Configuration().configure();
//2 创建一个SessionFactory对象,相当于JDBC连接池
SessionFactory sessionFactory = configuration.buildSessionFactory();
//3 通过SessionFactory获取到Session对象:类似于JDBC重Connection
Session session = sessionFactory.openSession();
//4 手动开启事务
Transaction transaction = session.beginTransaction();
//5 编写代码
Customer customer = new Customer();
customer.setCust_name("王可可");
session.save(customer);
//6 事务提交
transaction.commit();
//7资源释放
session.close();
} @Test
/*
*Hibernate工具类测试
*/
public void demo2(){
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
Customer customer = new Customer();
customer.setCust_name("工具类测试");
session.save(customer);
tx.commit();
session.close();
} @Test
/*
* 查询操作
*/
public void demo3(){
Session session = HibernateUtils.openSession();
Transaction transaction = session.beginTransaction();
//使用get方法
// Customer customer = session.get(Customer.class, 1l);
//使用load方法查询
Customer customer = session.load(Customer.class, 1l);
System.out.println(customer); transaction.commit();
session.close();
}
@Test
/*
* 修改操作
*/
public void demo4(){
Session session = HibernateUtils.openSession();
Transaction transaction = session.beginTransaction();
//直接创建对象进行修改,没有被set的属性会被置为null,不推荐
/*Customer customer = new Customer();
customer.setCust_id(1l);
customer.setCust_name("wangkeke");
session.update(customer);*/
//先查询再修改(推荐方式)
Customer customer = session.get(Customer.class, 1l);
customer.setCust_name("王改改");
session.update(customer);
transaction.commit();
session.close();
}
@Test
/*
* 删除操作
*/
public void demo5(){
Session session = HibernateUtils.openSession();
Transaction transaction = session.beginTransaction();
//直接创建对象进行删除,不推荐
/* Customer customer = new Customer();
customer.setCust_id(1l);
session.delete(customer);*/
//先查询再删除(推荐方式)
Customer customer = session.get(Customer.class, 2l);
session.delete(customer);
transaction.commit();
session.close();
}
@Test
/*
* 保存或者更新
*/
public void demo6(){
Session session = HibernateUtils.openSession();
Transaction transaction = session.beginTransaction(); Customer customer = new Customer();
customer.setCust_id(3l);
customer.setCust_name("王改改");
session.saveOrUpdate(customer);
transaction.commit();
session.close();
}
@Test
/*
* 查询所有
*/
public void demo7(){
Session session = HibernateUtils.openSession();
Transaction transaction = session.beginTransaction();
//接收HQL,Hibernate Query Language 面向对象的查询语言
Query query = session.createQuery("from Customer");
List<Customer> list = query.list();
for (Customer customer : list) {
System.out.println(customer);
}
//接收sql
SQLQuery query2 = session.createSQLQuery("select * from cst_customer");
List<Object[]> list2 = query2.list();
for (Object[] objects : list2) {
System.out.println(Arrays.toString(objects));
}
transaction.commit();
session.close();
}
}
Transaction对象:
Hibernate中管理事务的对象。
commit()
rollback()
一 Hibernate入门的更多相关文章
- 三大框架之hibernate入门
hibernate入门 1.orm hibernate是一个经典的开源的orm[数据访问中间件]框架 ORM( Object Relation Mapping)对象关 ...
- Hibernate入门案例及增删改查
一.Hibernate入门案例剖析: ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private I ...
- Hibernate入门案例 增删改
一.Hibernate入门案例剖析: ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private I ...
- Hibernate入门6.Hibernate检索方式
Hibernate入门6.Hibernate检索方式 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv Hibernate的整体框架已经 ...
- Hibernate入门5持久化对象关系和批量处理技术
Hibernate入门5持久化对象关系和批量处理技术 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv 前言: 前面学习了Hiberna ...
- Hibernate入门4.核心技能
Hibernate入门4.核心技能 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv 前言: 前面学习了Hibernate3的基本知识, ...
- Hibernate入门3.配置映射文件深入
Hibernate入门3.配置映射文件深入 2013.11.27 前言: 之前的两节是在Java项目中如何使用hibernate,并且通过一个简单地项目实践,期间有很多的错误,一般都是因为配置包的问题 ...
- 简单的Hibernate入门简介
其实Hibernate本身是个独立的框架,它不需要任何web server或application server的支持.然而,大多数的Hibernate入门介绍都加入了很多非Hibernate的东西, ...
- Hibernate入门(1)-第一个Hibernate程序
Hibernate入门(1)-第一个Hibernate程序 Hibernate是最著名的ORM工具之一,本系列文章主要学习Hibernate的用法,不涉及Hibernate的原理.本文介绍第一个Hib ...
- hibernate入门之person表
下面的hibernate入门person表指的是:根据mysql数据库中的test表和其中的元素-->建立映射表==>进而创建持久化类的顺序来操作了,下面为步骤 1.配置MySQL驱动程序 ...
随机推荐
- 最全面的C/C++编码规范总结
C语言是面向过程的,而C++是面向对象的 对于不同的编程语言来说,具体的编码规范可以有很大的不同,但是其宗旨都是一致的,就是保证代码在高质量完成需求的同时具备良好的可读性.可维护性.例如我们可以规定某 ...
- 杭电 1059 Dividing
Dividing Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- js脚本中执行java后台代码
使用场景:关闭页面弹窗时执行sql语句. 其实js里执行sql语句有多种方式. 方式一:直接在js代码里调用sql语句,原则上不能使用,因为这将sql直接暴露在客户端,安全性极差. 方式二:在js里运 ...
- proto school tutorial: blog: lesson 1
https://proto.school/#/blog/01 我们现在希望:把一个post 和他的作者联系起来. 从之前的教程here中,你可以知道, 一个cid 就是代表一个link 比如: { l ...
- 扒网站工具 HTTrack Website Copier
下载地址:http://www.pc6.com/softview/SoftView_30936.html 作者:匿名用户 链接:https://www.zhihu.com/question/34188 ...
- python字典操作方法详解
前言 字典是一种通过名字或者关键字引用的得数据结构,key 类型需要时被哈希,其键可以是数字.字符串.元组,这种结构类型也称之为映射.字典类型是Python中唯一內建的映射类型. 注意,浮点数比较很不 ...
- mybatis升级案例之CRUD操作
mybatis升级案例之CRUD操作 一.准备工作 1.新建maven工程,和入门案例一样 主要步骤如下,可参考mybatis入门实例 a.配置pom.xml文件 b.新建实例类User.DAO接口类 ...
- 20199317 myod实验
myod实验 实验内容: 1 复习c文件处理内容 2 编写myod.c 用myod XXX实现Linux下od -tx -tc XXX的功能 3 main与其他分开,制作静态库和动态库 4 编写Mak ...
- 入门项目数字手写体识别:使用Keras完成CNN模型搭建(重要)
摘要: 本文是通过Keras实现深度学习入门项目——数字手写体识别,整个流程介绍比较详细,适合初学者上手实践. 对于图像分类任务而言,卷积神经网络(CNN)是目前最优的网络结构,没有之一.在面部识别. ...
- vbs 入门
dim 定义变量名 dim name------------- dim name,agename = "worf"age = 20 msgbox 输出 msgbox name ...