Hibernate执行流程
创建Configuration对象(作用:读取配置文档:Hibernate.cfg.xml, 目的是创建SessionFactory对象)
创建SessionFactory对象(会读取相应的对象映射文件XXXX.hbm.xml,创建和销毁都相当耗费资源,通常一个系统内一个数据库只创建一个)
创建Session对象(类似于JDBC的Connection)
获取了Session对象就表示获取了数据库连接对象,那么就可以执行Session对象里面的方法(save\delete\update\get)
需要注意的是:执行某一个session
的方法时,必须开启一个事务Transaction
,也就是这些方法都需要封装在事务中.执行完session的方法后必须先提交事务再关闭session.
Hibernate常用配置
属性 | 含义 |
---|---|
hibernate.show_sql | 是否把hibernate运行时的SQL语句输出到控制台,用于测试。 |
hibernate.format_sql | 是否对输出到控制台的SQL语句进行排版,便于阅读。 |
hbm2ddl.auto | 可以帮助由java代码生成数据库脚本,进而生成具体的表结构。 [ create /update /create-drop /validate ] |
hibernate.default_schema | 默认的数据库(类似于表名前面加前缀) |
hibernate.dialect | 配置hibernate数据库方言,hibernate可针对特殊的数据库进行优化 |
session简介
1.Hibernate是对JDBC的一个封装,它不建议直接使用jdbc的connection操作数据库,而是通过使用session 操作数据库.那么我们可以简单理解session为操作数据库的对象.<br>
2.session与connection是多对一关系,每个session都有一个与之对应的connection,一个connection不同时刻可以供多个session使用.<br>
3.把对象保存在关系数据库中需要调用session的各种方法进行CURD等操作.<br>
transaction简介
hibernate对数据的操作都是封装在事务当中,并且默认是非自动提交的方式.所以用session保存对象时,如果不开启事务,并且手工提交事务,对象不会真正保存在数据库中.
如果想让Hibernate像jdbc那样自动提交事务,必须调用session对象的dowork()方法,获得jdbc的connection后,设置其为自动提交事务模式.(<b>通常不推荐这样做
</b>)
<code>
//示例代码
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.jdbc.Work;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
public class StudentsTest {
private SessionFactory sessionFactory;
private Session session;
private Transaction transaction;
@Before
public void init() {
//創建配置對象
Configuration config = new Configuration().configure();
//創建服務注冊對象
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().
applySettings(config.getProperties()).buildServiceRegistry();
//創建會話工廠對象
sessionFactory = config.buildSessionFactory(serviceRegistry);
//會話對象
session = sessionFactory.openSession();
//開啓事務
//transaction = session.beginTransaction();
}
@After
public void destory() {
//transaction.commit();//提交事務
session.close();//關閉會話
sessionFactory.close();//關閉會話工廠
}
@Test
public void testSaveStudents() {
//生成學生對象
Students s = new Students(1, "隔壁老王", "男", new Date(), "北京");
//自动提交事务
session.doWork(new Work(){
@Override
public void execute(Connection conn) throws SQLException {
conn.setAutoCommit(true);
}
});
session.save(s);
session.flush();
}
}
</code>