1 Configuration 配置对象
/详解Configuration对象 public class Configuration_test { @Test //Configuration 用户加载配置文件 public void fun1(){ //1.1 调用configure() 方法=> 加载src下名为hibernate.cfg.xml Configuration conf = new Configuration().configure(); //1.2 如果配置文件不符合默认加载规则.我们可以调用 //new Configuration().configure(file); 通过file加载 //new Configuration().configure(path); 通过路径加载 //1.3 可以通过Configuration对象加载 映射文件(不推荐) //推荐hibernate.cfg.xml 使用 mapping 属性引入配置文件 //规范: 1>orm映射文件名称与实体的简单类名一致 // 2>orm映射文件 需要与实体的类在同一包下 conf.addClass(User.class); } }
2 SessionFactory工厂
1)SessionFactory 相当于java web连接池,用于管理所有session
2)获得方式:config.buildSessionFactory();
3)sessionFactory hibernate缓存配置信息 (数据库配置信息、映射文件,预定义HQL语句 等)
4)SessionFactory线程安全,可以是成员变量,多个线程同时访问时,不会出现线程并发访问问题
5)提供api
//详解SessionFactory对象 public class sessionfactory_test { @Test //SessionFactory 创建session的工厂 public void fun1(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session //3.1 openSession => 获得一个全新的Session对象,测试环境下使用 sf.openSession(); //3.2 getCurrentSession => 获得与当前线程绑定的session对象 //将session与线程绑定 // 调用getCurrentSession 需要加上一个配置: <property name="hibernate.current_session_context_class">thread</property> sf.getCurrentSession(); } }
hibernate支持,将创建的session绑定到本地线程中,底层使用ThreadLocal,在程序之间共享session。
1.必须在hibernate.cfg.xml 配置
2.如果提交或回滚事务,底层将自动关闭session
3. Session 会话
1) Session 相当于 JDBC的 Connection -- 会话
2)通过session操作VO对象 --增删改查
3)session单线程,线程不安全,不能编写成成员变量
4)
l session api
save 保存
update 更新
delete 删除
get 通过id查询,如果没有 null
load 通过id查询,如果没有抛异常
createQuery("hql") 获得Query对象
createCriteria(Class) 获得Criteria对象
load方法.返回一个代理对象,获得其内容时,会查询数据库,不是每次都查.代理对象中有一个标识是否被初始化的boolean型变量. 记录是否被初始化过。
java中的动态代理是基于接口. 而 Hibernate 是使用javassist-3.12.0.GA.jar 产生代理对象的,该代理与被代理对象之间的关系是继承关系.与我们学的动态代理不是一种.所以不需要接口
package com.alice.hibernate01.api; 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.hql.ast.SqlASTFactory; import org.junit.Test; import com.alice.hibernate01.hello.User; public class SessionTest { @Test public void addTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); User user = new User(); user.setName("李良"); user.setPassword("1234"); //调用Session的save方法保存对象到数据库中 session.save(user); //提交事务 trac.commit(); //关闭资源 session.close(); sf.close(); } @Test public void updateTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); //先查询出你要修改的对象 User user = (User) session.get(User.class, 1); //在查询结果上,进行修改 user.setName("aaaa"); //提交事务 trac.commit(); //关闭资源 session.close(); sf.close(); } @Test public void deleteTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); //先查询出你要修改的对象 User user = new User(); user.setId(3); session.delete(user); //提交事务 trac.commit(); //关闭资源 session.close(); sf.close(); } @Test //Session对象 用于操作数据库 //查询get public void getTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); //查询 User user = (User) session.get(User.class, 4); System.out.println(user); trac.commit(); //关闭资源 session.close(); sf.close(); } @Test //Session对象 用于操作数据库 //查询 load public void loadTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); User user = (User) session.load(User.class, 5); System.out.println(user); trac.commit(); //关闭资源 session.close(); sf.close(); } @Test //Session对象 用于操作数据库 //查询所有User public void getAllTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); //HQL语言 => Hibernate Query Language //createQuery 传入hql语句查询 //select * from t_user; //session.createQuery("com.alice.hibernate01.hello.User") Query query = session.createQuery(" from User"); List<User> list = query.list(); System.out.println(list); trac.commit(); //关闭资源 session.close(); sf.close(); } @Test //Session对象 用于操作数据库 //查询所有User public void critieriaTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); //Criteria 查询 => Hibernate独创的面向对象的查询=> 无语句 Criteria criteria = session.createCriteria(User.class); //select * from t_user; List<User> list = criteria.list(); System.out.println(list); trac.commit(); //关闭资源 session.close(); sf.close(); } @Test //Session对象 用于操作数据库 //查询所有User public void sqlQueryTest(){ //1加载配置 Configuration conf = new Configuration().configure(); //2 根据Configuration 配置信息创建 SessionFactory SessionFactory sf = conf.buildSessionFactory(); //3 获得session Session session = sf.openSession(); //打开事务 Transaction trac = session.beginTransaction(); //原生的Sql查询 SQLQuery query = session.createSQLQuery("select * from t_user"); // addEntity 将查询结果封装到指定对象中 query.addEntity(User.class); List<User> list = query.list(); System.out.println(list); trac.commit(); //关闭资源 session.close(); sf.close(); } }