• Hibernate核心类和接口


    一、Hibernate核心类和接口预览图

    二、hibernate.properties

    这个文件是以前老版本使用的,类似于hibernate.cfg.xml文件,作用和hibernate.cfg.xml一致。

    三、hibernate.cfg.xml 

    (1)详细介绍

    • 该文件主要用于指定各个参数,是hibernate核心文件
    • 默认放在src目录下,也可以放在别的目录下
    • 指定连接数据库的驱动、用户名、密码、url、连接池
    • 指定对象关系映射文件的位置
    • 也可使用hibernate.properties文件来替代该文件.(推荐使用hibernate.cfg.xml)。

    (2)配置文件模板

    <?xml version='1.0' encoding='utf-8'?>
    <!DOCTYPE hibernate-configuration PUBLIC
            "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
            "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
    
    <hibernate-configuration>
    
        <session-factory>
    
            <!-- 数据库连接设置 -->
            <property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
            <property name="connection.url">jdbc:sqlserver://127.0.0.1:1433;DatabaseName=hibernate</property>
            <property name="connection.username">sa</property>
            <property name="connection.password">123456</property>
    
            <!-- SQL方言,即明确告诉Hibernate连接的是哪种数据库 -->
            <property name="dialect">org.hibernate.dialect.SQLServerDialect</property>
    
            <!-- 二级缓存设置,这里是关闭 -->
            <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
    
            <!-- 显示对应的SQL语句 -->
            <property name="show_sql">true</property>
            
             <!-- 格式化输出SQL语句 -->  
            <property name="format_sql">true</property>     
    
            <!-- Drop and re-create the database schema on startup -->
            <!-- 
            	update和create的区别:
            	create:每次先查询是否存在Student表,如果有则drop后再新建表,如果没有新建表
            	update:先查询是否存在Student表,如果有则更新数据(不会新建表,即使表结构发生变化),如果没有则新建表
             -->
    <!--    <property name="hbm2ddl.auto">create</property> -->
            <property name="hbm2ddl.auto">update</property>
            
    		<!-- 指定管理对象映射文件 -->
            <mapping resource="com/chongqing/hibernate/model/Student.hbm.xml"/>
    
        </session-factory>
    
    </hibernate-configuration>
    

    四、*.hbm.xml

    (1)对象关系映射文件(*.hbm.xml)

    • 该文件主要作用是建立表和类的映射关系,是不可或缺的重要文件
    • 一般放在其映射的类同一个目录下,但不是必须的
    • 命名方式一般是 类名.hbm.xml,但不是必须的
    • 示意图:

    (2)配置文件模板

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC
            "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
            "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.chongqing.hibernate.model">
    	<class name="Student" table="student">
    		<!-- id元素用于指定主键属性 -->  
    		<id name="id" column="id" type="java.lang.Integer">
    			<generator class="identity" />
    		</id>
    		
    		<!-- 对其他属性的配置 -->
    		<property name="name" type="java.lang.String">
    			<column name="name" not-null="false" />  
    		</property>
    		<property name="age" type="java.lang.Integer">
    			<column name="age" not-null="false" /> 
    		</property>
    	</class>
    </hibernate-mapping>
    

    五、Configuration类

    (1)详细介绍

    • 负责管理hibernate的配置信息
    • 读取hibernate.cfg.xml
    • 加载hibernate.cfg.xml配置文件中配置的驱动,url,用户名,密码,连接池
    • 管理 *.hbm.xml对象关系文件

    (2)示意代码

    //创建Configuration,该对象用于读取hibernate.cfg.xml配置文件,并完成初始化
    configuration = new Configuration().configure();
    

    六、SessionFactory(会话工厂)接口

    (1)详细介绍

    • 缓存sql语句和某些数据,它是重量级的
    • 之所以称SessionFactory是重量级的,是因为它需要一个很大的缓存,用来存放预定义的SQL语句及映射元素等
    • 在应用程序初始化的时候创建,是一个重量级的类(吃内存),一般用单例模式保证一个应用中只需要一个 SessionFactory实例
    • 如果某个应用访问多个数据库,则要创建多个会话工厂实例,一般是一个数据库一个会话工厂实例
    • 通过SessionFactory接口可以获得Session(会话)实例

    (2)示意代码

    //创建Configuration,该对象用于读取hibernate.cfg.xml配置文件,并完成初始化
    configuration = new Configuration().configure();
    		
    //创建SessionFactory,一个SessionFactory对应一个数据存储源
    sessionfactory = configuration.buildSessionFactory();	
    
    session = sessionfactory.openSession();
    //或者session = sessionfactory.getCurrentSession();
    

    七、Session(会话)接口

    (1)接口介绍 

    • Session一个实例代表与数据库的一次操作(当然一次操作可以是crud组合)
    • Session实例是轻量级的,所谓轻量级,是指它的创建和销毁不需要消耗太多的资源
    • Session实例通过SessionFactory获取,用完需要关闭
    • Session是线程不同步的(不安全),因此要保证在同一线程中使用,可以用getCurrentSessiong()
    • Session可以看做是持久化管理器,它是与持久化操作相关的接口

    (2)Session(会话)接口的几个重要方法

    初识化过程结束后,就可以调用SessionFactory实例的openSession()方法来获得Session实例,然后通过它来执行访问数据库的操作。Session接口提供了操作数据库的各自方法,如下:

    • 保存一个对象(记录)—save方法
    • 删除一个对象(记录)—delete方法
    • 查询一个对象(记录)—get/load方法
    • 修改一个对象(记录)—update方法

    八、Transaction(事务)接口

    (1)事务接口

    事务简单的说,就是一组对数据库的操作集合,它们要么全部成功,要么全部失败.这个可以保证数据的一致性,事务具有原子性。

    • Transaction是底层的事物实现中抽象出来的接口
    • 可能是一个jdbc或者jta的事务,这样有利于hibernate在不同执行环境的移植
    • Hibernate要求显示的调用事务(如果仅仅是查询可以不调用)
    try {			
    	session = sessionfactory.openSession();
    	ts = session.beginTransaction();
    	//do some work.....
    
    	ts.commit();
    		
    } catch (Exception e) {
    	e.printStackTrace();
    	if(ts!=null){
    		ts.rollback();
    	}
    }finally{
    	
    	if(session!=null&&session.isOpen()){
    		session.close();
    	}
    }
    

    (2)全局事务和本地事务

    本地事务:针对一个数据库的事务(jabc事务);
    全局事务:跨数据库的事务(jta事务); 

    九、Query接口

     Query接口类型的对象可以对数据库操作,它可以使用HQL,Qbc,Qbe和原生SQL(native Sql)对数据库操作,官方推荐使用HQL语句。

    Session session = null;
    		Transaction ts = null;
    		
    		try {
    			SessionFactory sessionfactory = MySessionFactory.getSessionFactory();
    			
    			session = sessionfactory.openSession();
    			ts = session.beginTransaction();
    			
    			//注意这里的Student不是表,而是domian类名
    			//where后面的条件即可以是表的字段名,也可以是domain类的属性,推荐使用类的属性名
    			Query query = (Query) session.createQuery("from Student where name='s1'");
    			
    			//通过list方法获取结果,这个list会自动的封装成对应的domain对象
    			//所以不用对jdbc进行二次封装
    			List<Student> list = query.list();
    
    			for(Student s:list) {
    				System.out.println("id="+s.getId()+"name="+s.getName());
    			}
    			ts.commit();
    			
    		} catch (Exception e) {
    			e.printStackTrace();
    			if(ts!=null){
    				ts.rollback();
    			}
    		}finally{
    			
    			if(session!=null&&session.isOpen()){
    				session.close();
    			}
    		}
    

    十、 Criteria接口

    Criteria接口也可用于面向对象方式的查询,Criteria一般用于条件查询

    Session session = null;
    		Transaction ts = null;
    		
    		try {
    			SessionFactory sessionfactory = MySessionFactory.getSessionFactory();
    			
    			session = sessionfactory.openSession();
    			ts = session.beginTransaction();
    			
    			//查询
    			Criteria criteria = session.createCriteria(Student.class).setMaxResults(4);
    			
    			List<Student> list = criteria.list();
    
    			for(Student s:list) {
    				System.out.println("id="+s.getId()+"name="+s.getName());
    			}
    			ts.commit();
    			
    		} catch (Exception e) {
    			e.printStackTrace();
    			if(ts!=null){
    				ts.rollback();
    			}
    		}finally{
    			
    			if(session!=null&&session.isOpen()){
    				session.close();
    			}
    		}
    
  • 相关阅读:
    安装MySQL56时,停止在start service这一步
    网站主机、域名购买和部署的方法
    sql修改数据库中表的结构
    放大电路的焊制实验
    win7下添加库文件出现“file is not regcognized”问题
    .net 网站中如何动态播放音乐,页面如何播放音乐
    LYF电子书制作工具(CHM格式)
    MVC创建
    ASP_Login
    智能搜索
  • 原文地址:https://www.cnblogs.com/yzy-blogs/p/6738360.html
Copyright © 2020-2023  润新知