hibernate学习笔记

12420171101

12420171101

Hibernate的体系结构【分层架构,作用:模块解耦】

   1)、java应用层(程序员编写)
   
   2)、持久化对象

   3)、Hibernate核心的api
	Configuration
	SessionFactory
	Session
	Transaction
	Query
	Criteria
	配置
		hibernate.cfg.xml(全局)
		hibernate.properties(全局)

   3)、数据库【oracle、db2、mysql、mssql等等】

1、编写一个简单hibernate示例程序的步骤

   1)、编写一个pojo类(根据数据表结构编写)

   2)、创建一个映射文件:类名.hbm.xml(写法必须这样,安装插件Jboss Tools-->hibernate Tools,会自动生成)

   3)、创建全局配置文件:hibernate.cfg.xml(写法必须这样)

2、基本数据库操作写法[以User实体类为例]

   1)、添加操作:session.save(user);

   2)、删除操作:session.delete(user);

   3)、更新操作:session.update(user);

   4)、查询操作:(session可以理解为数据库连接对象connection)
    
      (1)、User user = session.find(User.class,id);

      (2)、List
   
   
    
     userList = session.createQuery(" from User").list();

      (3)、List
    
    
     
      userList = session.createCriteria(User.class).list();
   
      模糊查询写法:Criteria criteria = session.createCriteria(User.class);

                    criteria.add(Expression.like("name", "李%"));

                    List
     
     
      
       userList = criteria.list();

      (4)、List
      
      
       
        userList = session.createNativeQuery("select from user").addEntity(User.class).getResultList();

3、Configuration:配置全局信息(properties、hibernate.cfg.xml)

   1)、数据库连接信息

   2)、数据源连接池配置信息

   3)、数据库方言(见图表):org.hibernate.dialect.MySQL5InnoDBDialect

   4)、数据源连接池配置信息

   5)、缓存

   6)、事务

   7)、指定映射文件

   8)、......

4、SessionFactory对象:特点如下

   1)、整个应用只有一个SessionFactory,如果应用使用多种数据库,一个数据库对应一个SessionFactory对象

   2)、SessionFactory线程安全

   3)、SessionFactory它是一个重量级的对象

5、Session对象

   1)、轻量级

   2)、线程不安全(其底层通过ThreadLocal类包装,每个线访问的其实是它的副本)

   3)、针对持久化对象进行操作(save、delete、createQuery、flush、等等)

6、Transaction类:在hibernate框架里面实现添加、删除、更新必须要创建事务处理

7、持久化对象的状态(重点)[持久化对象图查看之间的关系]

   1)、瞬态:对象由new关键字创建后,尚未与Session对象结合

   2)、持久态:对象与Session对象结合起来,特点:处于持久态的对象,发生改变,它会回写到相应的数据库(存于缓存中,需要session.flush();才正真持久到数据库),开发者并不需要调用相应的update方法

   3)、托管/游离:对象与Session对象相分离

   4)、各状态之间的转换关系:
      
      (1)、瞬态 --> 持久态
          save(pojo对象):保存对象(返回生成主键ID)
          saveOrUpdate(pojo对象):
          persist(pojo对象):保存对象(没有返回值)
          merge(pojo对象):并没有从瞬态切换到持久态

      (2)、直接通过已经存在的实体类对象的ID获得持久化对象:User user = session.load(User.class, 1); | User user = session.get(User.class, 1); 

      (3)、持久态 --> 托管/游离: clear();清除session会话缓存。 | close();关闭session对象,释放内存。 | evict(pojo对象);指明清除那些对象缓存。 

      (4)、托管/游离 --> 持久态:update(pojo对象); | saveOrUpdate(pojo对象);

      (5)、flush();将session内存同步到数据库表,其实在事务提交时调用了这个方法 
       
          

       
          
   
    
       
               
    
       
        
         
         
          
          
         
           com.mysql.jdbc.Driver 
          
          
         
           jdbc:mysql://localhost:3306/dbname 
          
          
         
           root 
          
          
         
           123456 
          
          
         
           org.hibernate.dialect.MySQLDialect 
          
          
          
         
           false 
          
          
         
           true 
          
          
         
           utf-8 
          
          
         
           20 
          
          
         
           30 
          
         
           10 
          
         
           5000 
          
          
          
          
         
           50 
          
          
         
           23 
          
          
          
         
           true 
          
          
         
           update 
          
          
         
           true 
          
         
           org.hibernate.cache.EhCacheProvider 
          
          
         
           true 
          
          
          
          
          
         
         
       
       


       
        
         
         
          
          
           
          
          
           
          
          
           
          
          
           
          
          
           
          
         
       属性名	用途
hibernate.dialect	一个Hibernate Dialect类名允许Hibernate针对特定的关系数据库生成优化的SQL. 取值 full.classname.of.Dialect
hibernate.show_sql	输出所有SQL语句到控制台. 有一个另外的选择是把org.hibernate.SQL这个log category设为debug。 eg. true | false
hibernate.format_sql	在log和console中打印出更漂亮的SQL。 取值 true | false
hibernate.default_schema	默认的数据库。例如:如果设置为pubs,则生成SQL语句时,所有的数据库表前都会出现pubs字样,可能生成如下的SQL语句:select id,name,sex form pubs.UserInfo(其中UserInfo是数据库pubs的表,id、name、sex是表UserInfo中的3个字段)
hibernate.default_catalog	在生成的SQL中, 将给定的catalog附加于非全限定名的表名上. 取值 CATALOG_NAME
hibernate.session_factory_name	SessionFactory创建后,将自动使用这个名字绑定到JNDI中. 取值 jndi/composite/name
hibernate.max_fetch_depth	为单向关联(一对一, 多对一)的外连接抓取(outer join fetch)树设置最大深度. 值为0意味着将关闭默认的外连接抓取. 取值 建议在0到3之间取值
hibernate.default_batch_fetch_size	为Hibernate关联的批量抓取设置默认数量. 取值 建议的取值为4, 8, 和16
hibernate.default_entity_mode	为由这个SessionFactory打开的所有Session指定默认的实体表现模式. 取值 dynamic-map, dom4j, pojo
hibernate.order_updates	强制Hibernate按照被更新数据的主键,为SQL更新排序。这么做将减少在高并发系统中事务的死锁。 取值 true | false
hibernate.generate_statistics	如果开启, Hibernate将收集有助于性能调节的统计数据. 取值 true | false
hibernate.use_identifer_rollback	如果开启, 在对象被删除时生成的标识属性将被重设为默认值. 取值 true | false
hibernate.use_sql_comments	如果开启, Hibernate将在SQL中生成有助于调试的注释信息, 默认值为false. 取值 true | false

 

Hibernate JDBC和连接(connection)属性

属性名	用途
hibernate.jdbc.fetch_size	非零值,指定JDBC抓取数量的大小 (调用Statement.setFetchSize()).
hibernate.jdbc.batch_size	非零值,允许Hibernate使用JDBC2的批量更新. 取值 建议取5到30之间的值
hibernate.jdbc.batch_versioned_data	如果你想让你的JDBC驱动从executeBatch()返回正确的行计数 , 那么将此属性设为true(开启这个选项通常是安全的). 同时,Hibernate将为自动版本化的数据使用批量DML. 默认值为false. eg. true | false
hibernate.jdbc.factory_class	选择一个自定义的Batcher. 多数应用程序不需要这个配置属性. eg. classname.of.Batcher
hibernate.jdbc.use_scrollable_resultset	允许Hibernate使用JDBC2的可滚动结果集. 只有在使用用户提供的JDBC连接时,这个选项才是必要的, 否则Hibernate会使用连接的元数据. 取值 true | false
hibernate.jdbc.use_streams_for_binary	在JDBC读写binary (二进制)或serializable (可序列化) 的类型时使用流(stream)(系统级属性). 取值 true | false
hibernate.jdbc.use_get_generated_keys	在数据插入数据库之后,允许使用JDBC3 PreparedStatement.getGeneratedKeys() 来获取数据库生成的key(键)。需要JDBC3+驱动和JRE1.4+, 如果你的数据库驱动在使用Hibernate的标 识生成器时遇到问题,请将此值设为false. 默认情况下将使用连接的元数据来判定驱动的能力. 取值 true|false
hibernate.connection.provider_class	自定义ConnectionProvider的类名, 此类用来向Hibernate提供JDBC连接. 取值 classname.of.ConnectionProvider
hibernate.connection.isolation	设置JDBC事务隔离级别. 查看java.sql.Connection来了解各个值的具体意义, 但请注意多数数据库都不支持所有的隔离级别. 取值 1, 2, 4, 8
hibernate.connection.autocommit	允许被缓存的JDBC连接开启自动提交(autocommit) (不建议). 取值 true | false
hibernate.connection.release_mode	指定Hibernate在何时释放JDBC连接. 默认情况下,直到Session被显式关闭或被断开连接时,才会释放JDBC连接. 对于应用程序服务器的JTA数据源, 你应当使用after_statement, 这样在每次JDBC调用后,都会主动的释放连接. 对于非JTA的连接, 使用after_transaction在每个事务结束时释放连接是合理的. auto将为JTA和CMT事务策略选择after_statement, 为JDBC事务策略选择after_transaction. 取值 on_close | after_transaction | after_statement | auto
hibernate.connection.
       
       
         将JDBC属性propertyName传递到DriverManager.getConnection()中去. hibernate.jndi. 
        
          将属性propertyName传递到JNDI InitialContextFactory中去. Hibernate缓存属性 属性名 用途 hibernate.cache.provider_class 自定义的CacheProvider的类名. 取值 classname.of.CacheProvider hibernate.cache.use_minimal_puts 以频繁的读操作为代价, 优化二级缓存来最小化写操作. 在Hibernate3中,这个设置对的集群缓存非常有用, 对集群缓存的实现而言,默认是开启的. 取值 true|false hibernate.cache.use_query_cache 允许查询缓存, 个别查询仍然需要被设置为可缓存的. 取值 true|false hibernate.cache.use_second_level_cache 能用来完全禁止使用二级缓存. 对那些在类的映射定义中指定 
         
           的类,会默认开启二级缓存. 取值 true|false hibernate.cache.query_cache_factory 自定义实现QueryCache接口的类名, 默认为内建的StandardQueryCache. 取值 classname.of.QueryCache hibernate.cache.region_prefix 二级缓存区域名的前缀. 取值 prefix hibernate.cache.use_structured_entries 强制Hibernate以更人性化的格式将数据存入二级缓存. 取值 true|false Hibernate事务属性 属性名 用途 hibernate.transaction.factory_class 一个TransactionFactory的类名, 用于Hibernate Transaction API (默认为JDBCTransactionFactory). 取值 classname.of.TransactionFactory jta.UserTransaction 一个JNDI名字,被JTATransactionFactory用来从应用服务器获取JTA UserTransaction. 取值 jndi/composite/name hibernate.transaction.manager_lookup_class 一个TransactionManagerLookup的类名 - 当使用JVM级缓存,或在JTA环境中使用hilo生成器的时候需要该类. 取值 classname.of.TransactionManagerLookup hibernate.transaction.flush_before_completion 如果开启, session在事务完成后将被自动清洗(flush)。 现在更好的方法是使用自动session上下文管理。取值 true | false hibernate.transaction.auto_close_session 如果开启, session在事务完成后将被自动关闭。 现在更好的方法是使用自动session上下文管理。取值 true | false 其他属性 属性名 用途 hibernate.current_session_context_class 为"当前" Session指定一个(自定义的)策略。eg. jta | thread | custom.Class hibernate.query.factory_class 选择HQL解析器的实现. 取值 org.hibernate.hql.ast.ASTQueryTranslatorFactory or org.hibernate.hql.classic.ClassicQueryTranslatorFactory hibernate.query.substitutions 将Hibernate查询中的符号映射到SQL查询中的符号 (符号可能是函数名或常量名字). 取值 hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC hibernate.hbm2ddl.auto 该属性可帮助程序员实现正向工程, 即由 java 代码生成数据库脚本, 进而生成具体的表结构。 取值 create | update | create-drop | validate create : 会根据 .hbm.xml 文件来生成数据表, 但是每次运行都会删除上一次的表 ,重新生成表, 哪怕二次没有任何改变 create-drop : 会根据 .hbm.xml 文件生成表,但是SessionFactory一关闭, 表就自动删除 update : 最常用的属性值,也会根据 .hbm.xml 文件生成表, 但若 .hbm.xml 文件和数据库中对应的数据表的表结构不同, Hiberante 将更新数据表结构,但不会删除已有的行和列 validate : 会和数据库中的表进行比较, 若 .hbm.xml 文件中的列在数据表中不存在,则抛出异常 hibernate.cglib.use_reflection_optimizer 开启CGLIB来替代运行时反射机制(系统级属性). 反射机制有时在除错时比较有用. 注意即使关闭这个优化, Hibernate还是需要CGLIB. 你不能在hibernate.cfg.xml中设置此属性. 取值 true | false Hibernate SQL方言 (hibernate.dialect) RDBMS 方言 DB2 org.hibernate.dialect.DB2Dialect DB2 AS/400 org.hibernate.dialect.DB2400Dialect DB2 OS390 org.hibernate.dialect.DB2390Dialect PostgreSQL org.hibernate.dialect.PostgreSQLDialect MySQL org.hibernate.dialect.MySQLDialect MySQL with InnoDB org.hibernate.dialect.MySQLInnoDBDialect MySQL with MyISAM org.hibernate.dialect.MySQLMyISAMDialect Oracle (any version) org.hibernate.dialect.OracleDialect Oracle 9i/10g org.hibernate.dialect.Oracle9Dialect Sybase org.hibernate.dialect.SybaseDialect Sybase Anywhere org.hibernate.dialect.SybaseAnywhereDialect Microsoft SQL Server org.hibernate.dialect.SQLServerDialect SAP DB org.hibernate.dialect.SAPDBDialect Informix org.hibernate.dialect.InformixDialect HypersonicSQL org.hibernate.dialect.HSQLDialect Ingres org.hibernate.dialect.IngresDialect Progress org.hibernate.dialect.ProgressDialect Mckoi SQL org.hibernate.dialect.MckoiDialect Interbase org.hibernate.dialect.InterbaseDialect Pointbase org.hibernate.dialect.PointbaseDialect FrontBase org.hibernate.dialect.FrontbaseDialect Firebird org.hibernate.dialect.FirebirdDialect Hibernate日志类别 类别 功能 org.hibernate.SQL 在所有SQL DML语句被执行时为它们记录日志 org.hibernate.type 为所有JDBC参数记录日志 org.hibernate.tool.hbm2ddl 在所有SQL DDL语句执行时为它们记录日志 org.hibernate.pretty 在session清洗(flush)时,为所有与其关联的实体(最多20个)的状态记录日志 org.hibernate.cache 为所有二级缓存的活动记录日志 org.hibernate.transaction 为事务相关的活动记录日志 org.hibernate.jdbc 为所有JDBC资源的获取记录日志 org.hibernate.hql.AST 在解析查询的时候,记录HQL和SQL的AST分析日志 org.hibernate.secure 为JAAS认证请求做日志 org.hibernate 为任何Hibernate相关信息做日志 (信息量较大, 但对查错非常有帮助) JTA TransactionManagers Transaction工厂类 应用程序服务器 org.hibernate.transaction.JBossTransactionManagerLookup JBoss org.hibernate.transaction.WeblogicTransactionManagerLookup Weblogic org.hibernate.transaction.WebSphereTransactionManagerLookup WebSphere org.hibernate.transaction.WebSphereExtendedJTATransactionLookup WebSphere 6 org.hibernate.transaction.OrionTransactionManagerLookup Orion org.hibernate.transaction.ResinTransactionManagerLookup Resin org.hibernate.transaction.JOTMTransactionManagerLookup JOTM org.hibernate.transaction.JOnASTransactionManagerLookup JOnAS org.hibernate.transaction.JRun4TransactionManagerLookup JRun4 org.hibernate.transaction.BESTransactionManagerLookup Borland ES 
          
         
       
      
      
     
     
    
    
   
   

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ljt-tiger

thanks

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值