Hibernate基础学习(一)—初识Hibernate
一、对象的持久化
狭义的理解: 持久化仅仅指把对象永久的保存到数据库中。
广义的理解: 持久化包括和数据库相关的各种操作。
保存: 把对象永久保存到数据库中。
更新: 更新数据库中对象的状态。
删除: 从数据库中删除一个对象。
查询: 根据特定的查询条件,把符合查询条件的一个或者多个对象加载到内存中。
二、ORM
ORM(Object-Relation-Mapping),对象关系映射。
ORM的思想: 将关系数据库中的表的记录映射成对象,以对象形式展现,可以把对数据库的操作转化成对对象的操作。


三、Hibernate的配置
1.复制jar包到工程中

2.创建实体类
User.java
public class User{
private Integer uid;
private String username;
private String password;
public User(){
super();
}
public User(String username,String password){
super();
this.username = username;
this.password = password;
}
//getXxx、setXxx...
}
3.创建对象关系映射文件
User.hbm.xml
<?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.kiwi.domain.User" table="t_user"> <!-- 配置主键 -->
<id name="uid">
<!-- 主键生成策略 -->
<generator class="native"></generator>
</id> <!-- 普通属性 -->
<property name="username"></property>
<property name="password"></property> </class> </hibernate-mapping>
4.创建Hibernate配置文件
hibernate.cfg.xml
<?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> <!-- SessionFactory相当于连接池的配置 -->
<session-factory> <!-- 基本四项 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property> <!-- Hibernate 的基本配置 -->
<!-- Hibernate 使用的数据库方言 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 运行时是否打印 SQL -->
<property name="show_sql">true</property> <!-- 运行时是否格式化 SQL -->
<property name="format_sql">true</property> <!-- 添加映射文件 -->
<mapping resource="com/kiwi/domain/User.hbm.xml" /> </session-factory> </hibernate-configuration>
5.测试
@Test
public void testHello(){ //1.加载配置文件获取核心配置对象
Configuration config = new Configuration().configure(); //2.获得SessionFactory
SessionFactory factory = config.buildSessionFactory(); //3.获取会话session
Session session = factory.openSession(); //4.开启事务
Transaction tx = session.beginTransaction(); //操作
session.save(new User("Tom","123456")); //5.提交事务 | 回滚事务
tx.commit(); //6.释放资源---关闭session
session.close(); //7.释放资源---关闭factory
factory.close();
}
结果:

四、数据的CRUD
HibernateUtils.Java
public class HibernateUtils{
private static SessionFactory factory;
static{
// 初始化SessionFactory
factory = new Configuration() //
.configure() //
.buildSessionFactory();
}
// 获取全局唯一 的SessionFactory
public static SessionFactory getFactory(){
return factory;
}
// 获取session
public static Session getSession(){
return factory.openSession();
}
}
UserDao.java
public class UserDao{
/*
* 保存数据
*/
public void save(User user){
Session session = HibernateUtils.getSession();
Transaction tx = null;
try{
// 开启事务
tx = session.beginTransaction();
// 保存数据
session.save(user);
// 提交事务
tx.commit();
}catch(RuntimeException e){
// 回滚事务
tx.rollback();
throw e;
}finally{
// 释放资源
session.close();
}
}
/*
* 更新数据
*/
public void update(User user){
Session session = HibernateUtils.getSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
// 更新数据
session.update(user);
tx.commit();
}catch(RuntimeException e){
tx.rollback();
throw e;
}finally{
session.close();
}
}
/*
* 删除数据
*/
public void delete(int id){
Session session = HibernateUtils.getSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
// 删除数据 : 先查询再删除对象
Object object = session.get(User.class,id);
session.delete(object);
tx.commit();
}catch(RuntimeException e){
tx.rollback();
throw e;
}finally{
session.close();
}
}
/*
* 查询单条数据
*/
public User findById(int id){
Session session = HibernateUtils.getSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
// 查询数据
User user = (User)session.get(User.class,id);
tx.commit();
return user;
}catch(RuntimeException e){
tx.rollback();
throw e;
}finally{
session.close();
}
}
/*
* 查询所有数据
*/
@SuppressWarnings("unchecked")
public List<User> findAll(){
Session session = HibernateUtils.getSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
// 查询数据
List<User> list = session.createQuery("FROM User") // 使用HQL语句
.list();
tx.commit();
return list;
}catch(RuntimeException e){
tx.rollback();
throw e;
}finally{
session.close();
}
}
/*
* 查询数据,带分页
*/
@SuppressWarnings("unchecked")
public QueryResult findAllByPage(int firstResult,int maxResults){
Session session = HibernateUtils.getSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
// 查询一页数据
List<User> list = session.createQuery("FROM User") //
.setFirstResult(firstResult) //
.setMaxResults(maxResults) //
.list();
// 查询总记录数
Long count = (Long)session.createQuery( //
"SELECT COUNT(*) FROM User") //
.uniqueResult();
tx.commit();
return new QueryResult(list,count.intValue());
}catch(RuntimeException e){
tx.rollback();
throw e;
}finally{
session.close();
}
}
}
UserDaoTest.java
public class UserDaoTest{
private UserDao userDao = new UserDao();
@Test
public void testSave(){
for(int i = 0;i < 30;i++){
userDao.save(new User("test_" + i,"" + i));
}
}
@Test
public void testUpdate(){
//从数据库获取存在的数据
User user = userDao.findById(1);
user.setUsername("MMM");
userDao.update(user);
}
@Test
public void testDelete(){
userDao.delete(1);
}
@Test
public void testFindById(){
User user = userDao.findById(1);
System.out.println(user);
}
@Test
public void testFindAll(){
List<User> list = userDao.findAll();
for(User user : list){
System.out.println(user);
}
}
@Test
public void testFindAllByPage(){
QueryResult qr = userDao.findAllByPage(0,10); //第一页10条
System.out.println("总条数: " + qr.getCount());
for(Object user : qr.getList()){
System.out.println(user);
}
}
}
Hibernate基础学习(一)—初识Hibernate的更多相关文章
- Hibernate基础学习2
Hibernate基础学习2 测试hibernate的一级缓存,事务以及查询语句 1)Hibernate的一些相关概念 hibernate的一级缓存 1)缓存是为了提高该框架对数据库的查询速度 2)一 ...
- Hibernate基础学习(二)—Hibernate相关API介绍
一.Hibernate的核心接口 所有的Hibernate应用中都会访问Hibernate的5个核心接口. (1)Configuration接口: 配置Hibernate,启动Hi ...
- hibernate基础学习---hierbnate2级缓存
1:开启二级缓存sessionFactory需要安装jar包 2:在实体类配置文件添加(配置二级缓存).我的配置文件是Account.hbm.xml <?xml version="1. ...
- Hibernate基础学习(五)—对象-关系映射(下)
一.单向n-1 单向n-1关联只需从n的一端可以访问1的一端. 域模型: 从Order到Customer的多对一单向关联.Order类中定义一个Customer属性,而在Customer类不用存放Or ...
- Hibernate基础学习(四)—对象-关系映射(上)
一.映射对象标识符 Java语言按内存地址来识别或区分同一个类的不同对象,而关系数据库按主键值来识别或区分同一个表的不同记录.Hibernate使用对象标识符(OID)来建立内存中的对象和数 ...
- hibernate基础学习
转载自:http://blog.csdn.net/fb281906011/article/details/17628111 一:下载hibernate:http://hibernate.org/orm ...
- Hibernate基础学习(七)—检索方式
一.概述 Hibernate有五种检索方式. 1.导航对象图检索方式 根据已经加载的对象,导航到其他对象. Order order = (Order)session.get(Ord ...
- Hibernate基础学习(六)—Hibernate二级缓存
一.概述 Session的缓存是一块内存空间,在这个内存空间存放了相互关联的Java对象,这个位于Session缓存内的对象也被称为持久化对象,Session负责根据持久化对象的状态来同步更 ...
- Hibernate基础学习(三)—Session
一.概述 Session接口是Hibernate向应用程序提供的操纵数据库最主要的接口,它提供了基本的保存.更新.删除和加载Java对象的方法. Session具有一个缓存,位于缓 ...
随机推荐
- mfc---单文档工程添加消息响应
写消息映射:.h中些函数头文件afx_mag … .cpp中写函数体 .cpp中写消息映射 给toolbar添加消息: .h中添加头文件afx_msg …. .cpp中添加函数体,消息映射ON_COM ...
- Spring+SpringMVC+MyBatis+easyUI整合基础篇(八)mysql中文查询bug修复
写在前面的话 在测试搜索时出现的问题,mysql通过中文查询条件搜索不出数据,但是英文和数字可以搜索到记录,中文无返回记录.本文就是写一下发现问题的过程及解决方法.此bug在第一个项目中点这里还存在, ...
- AR入门系列-05-Vuforia识别目标视频播放
在识别目标后播放视频我们需要一个插件 Easy Movie Texture 2.36.unitypackage 百度网盘下载地址:http://pan.baidu.com/s/1skT8Xp7 将Ea ...
- 我在ubuntu桌面系统下进行WEB开发常用的软件
公司电脑本来是win系统的,不知道怎么突然中毒了,由于比较讨厌杀毒软件,所以之前都被我卸载掉了,所以我干脆重装了一个ubuntu系统 1.IDE vscode 各种插件,自带Git,markdo ...
- laravel初次学习总结及一些细节
最近学习了laravel,先简单谈谈学习的感受吧 刚开始一周多一点的时间先把laravel的开发文档看了一遍,,感觉刚开始接触时的感觉laravel的目录与thinkphp又不一样,它们的渲染模板的方 ...
- ACM 比大小
比大小 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 给你两个很大的数,你能不能判断出他们两个数的大小呢? 比如123456789123456789要大于-1234 ...
- HAproxy健康检查的三种方式
1.通过监听端口进行健康检测 .这种检测方式,haproxy只会去检查后端server的端口,并不能保证服务的真正可用. 配置示例: listen http_proxy mode http cooki ...
- Java容器源码解析之——ArrayList
public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess ...
- 浅谈jquery插件开发模式
首先根据<jQuery高级编程>的描述来看,jQuery插件开发方式主要有三种: 通过$.extend()来扩展jQuery 通过$.fn 向jQuery添加新的方法 通过$.widget ...
- 【收集】sql查询统计,周,月,年
昨天 select * from tb where datediff(day, 时间字段 ,getdate()) = 1 今天 select * from tb where datediff(day, ...