什么是Hibernate?
是基于ORM(O:对象,R:关系,M:映射)映射的持久层框架,是一个封装JDBC的轻量级框架,主要实现了对数据库的操作。
注:CRUD是指在做计算处理时的增加(Create)、查询(Retrieve)(重新得到数据)、更新(Update)和删除(Delete)几个单词的首字母简写。主要被用在描述软件系统中数据库或者持久层的基本操作功能。
Hibernate中的核心接口和类
Hibernate的核心类和接口一共有6个,分别为:Session、SessionFactory、Transaction、Query、Criteria和Configuration。这6个核心类和接口在任何开发中都会用到。通过这些,不仅可以对持久化对象进行存取,还能够进行事务控制。
Session接口:负责对象的持久化操作,但需要注意的是它非的。
SessionFactory接口:负责Hibernate的初始化操作,数据存储的代理对象,并且负责创建Session对象,
Transaction接口:负责数据的事务操作。
Query接口:负责数据库及持久化对象的查询操作,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作。
Criteria接口:Criteria接口与Query接口非常类似,允许创建并执行面向对象的标准化查询。值得注意的是Criteria接口也是轻量级的,它不能在Session之外使用。
Configuration类:Configuration 类的作用是对Hibernate 进行配置,以及对它进行启动。在Hibernate 的启动过程中,Configuration 类的实例首先定位映射文档的位置,读取这些配置,然后创建一个SessionFactory对象。虽然Configuration 类在整个Hibernate 项目中只扮演着一个很小的角色,但它是启动hibernate 时所遇到的第一个对象。
Hibernate的工作流程:
工作流程图:
Hibernate持久化操作的七个步骤:
1.创建Configuration对象,并加载cfg.xml配置文件;(配置文件可以通过Eclipse自动生成)
2.通过Configuration对象构建SessionFactory工厂;
3.通过SessionFactory工厂打开一个Session会话;
4.开启事务;(查询方法可省略)
5.用Session会话进行数据库及持久化对象的CRUD操作;
6.提交事务;(查询方法可省略)
7.关闭会话;
代码如下:
import java.util.List;import org.hibernate.Criteria;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.hibernate.criterion.Restrictions;public class HibernateTest { public void Test(){ //创建Configurtion对象并加载cfg.xml配置文件 Configuration conf = new Configuration().configure("hibernate.cfg.xml"); //构建SessionFactory工厂 SessionFactory sessionFactory = conf.buildSessionFactory(); //打开Session会话 Session session = sessionFactory.openSession(); //开启事务(增删改)需要开启事务 查询可以不用开启事务 Transaction transaction = session.beginTransaction(); //创建Users类对象 Users users = new Users(); /** * Session中封装的几个常用的方法 */ //调用Session中添加的方法 session.save(users); //调用Session中删除的方法 session.delete(users); //调用Session中修改的方法 session.update(users); //调用Session中根据主键查询某个类的方法 session.get(Users.class,users.getId()); //根据HQL语句查询 String hql = "from Users"; Query query = session.createQuery(hql); ListuserList = query.list(); //根据SQL语句查询 String sql = "select * from Users"; SQLQuery sqlQuery = session.createSQLQuery(sql); List sqlUsersList = sqlQuery.list(); //根据你给的Bean.class类来指定查询哪个类 Criteria criteria = session.createCriteria(Users.class); //用Criteria对象来添加条件(括号中用Restrictions对象来选择你要添加哪一种条件) criteria.add(Restrictions.ilike("name", "华盛顿%")); /** * 提交事务后将对数据库进行增删改查操作 * 可以通过条件判断来确定是否提交事务 * 例如: * 如果程序运行正常提交事务 * 否则让事务回滚 * 回滚后将不对数据库进行操作 * 事务的回滚: transaction.rollback(); */ //提交事务 transaction.commit(); //关闭Session会话释放资源 session.close(); } }