Hibernate映射类型
Hibernate映射类型是Java类型与标准SQL类型相互转换的桥梁。
hibernate映射类型有以下三类:
Java基本类型对应的Hibernate映射类型
Java时间和日期类型对应的Hibernate映射类型
Java 大对象类型对应的Hibernate映射类型
Hibernate的缓存机制
缓存的作用是降低应用程序直接读写永久性数据存储源的频率,从而提高应用的运行性能。
缓存介于应用程序和永久性数据存储源之间,存放了应用程序频繁读写的数据。其中的数据是数据存储源中数据的复制,应用程序在运行时直接读写缓存中的数据。
缓存通常是一块内存空间,当缓存的数据量比较大时,也会使用硬盘作为缓存
hibernate缓存级别:
事务级别(Session级别,一级缓存,内置缓存)
应用/进程级别(SessionFactory级别,二级缓存,需设置后才能使用)
Hibernate的两级缓存结构:
应用程序在加载数据时,首先会在Session缓存中查询,如果找到直接返回;否则到SessionFactory缓存中查询,如果找到直接返回;否则到数据库中查询
一级缓存概述:
缓存介质为内存。
当应用程序调用Session的save、persist、update、saveOrUpdate、load、get方法,以及调用Query查询接口的list、iterator等方法时,如果在Session缓存中不存在相应的对象,Hibernate就会把该对象加入到一级缓存中。
当清理缓存时,Hibernate会根据缓存中对象的状态变化来同步更新数据库。
清理一级缓存的方法:
evict(Object o):从缓存中清除参数指定的持久化对象。
clear():清空缓存中所有持久化对象。
二级缓存配置步骤:
将所用的缓存插件的jar文件添中到项目中。
在hibernate.cfg.xml文件中开启二级缓存,并指定缓存适配置器;使用或对指定的持久化类或集合配置并发访问策略(read-only、read-write等)。
在src目录下创建所选择的缓存插件的配置文件(如ehcache.xml),并在其中设置二级缓存的数据过期策略。
二级缓存配置示例:
1.在hibernate.cfg.xml中配置以下属性开启二级缓存并指定缓存适配器:
2.在hibernate.cfg.xml中使用配置以下内容配置并发访问策略:
3.在src中创建ehcache.xml,并配置以下内容设置数据过期策略:
使用Tomcat连接池
把数据库驱动文件拷贝到Tomcat的lib目录下
Tomcat数据库连接池的配置如下:
在Tomcat安装目录\conf\context.xml下添加以下设置:
使用Tomcat连接池时,需要将hibernate.cfg.xml中的数据库连接属性设置修改为以下设置内容:
<property name="connection.datasource">
java:comp/env/jdbc/mysql
</property>
在Hibernate中使用c3p0连接池
c3p0是与Hibernate一同发布的开源的JDBC连接池,在Hibernate中使用时首先要导入hibernate的lib>>optional>>c3p0下的所有JAR文件,且需要在hibernate.cfg.xml中作以下配置:
<!--指定使用c3p0连接池 -->
<property name="connection.provider_class">
org.hibernate.connection.C3P0ConnectionProvider</property>
<!--连接池中保留的最大连接数 -->
<property name="c3p0.max_size">30</property>
<!--连接池中保留的最小连接数 -->
<property name="c3p0.min_size">10</property>
<!--获取连接的超时时间,单位是毫秒 -->
<property name="c3p0.timeout">500</property>
<!--最大的PrepareStatement的数量 -->
<property name="c3p0.max_statements">100</property>
hibernate项目既可使用服务器的连接池,也可以使用第三方连接池。
示例
上传之后我会在这里加入链接方式
pom.xml导入的依赖:
<dependencies>
<!-- https://mvnrepository.com/artifact/antlr/antlr -->
<dependency>
<groupId>antlr</groupId>
<artifactId>antlr</artifactId>
<version>2.7.7</version>
</dependency>
<!-- https://mvnrepository.com/artifact/net.bytebuddy/byte-buddy -->
<dependency>
<groupId>net.bytebuddy</groupId>
<artifactId>byte-buddy</artifactId>
<version>1.10.10</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.fasterxml/classmate -->
<dependency>
<groupId>com.fasterxml</groupId>
<artifactId>classmate</artifactId>
<version>1.5.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.dom4j/dom4j -->
<dependency>
<groupId>org.dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>2.1.3</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.sun.xml.fastinfoset/FastInfoset -->
<dependency>
<groupId>com.sun.xml.fastinfoset</groupId>
<artifactId>FastInfoset</artifactId>
<version>1.2.15</version>
</dependency>
<dependency>
<groupId>org.hibernate.common</groupId>
<artifactId>hibernate-commons-annotations</artifactId>
<version>5.1.0.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>5.4.22.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.sun.istack/istack-commons-runtime -->
<dependency>
<groupId>com.sun.istack</groupId>
<artifactId>istack-commons-runtime</artifactId>
<version>3.0.7</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.jboss/jandex -->
<dependency>
<groupId>org.jboss</groupId>
<artifactId>jandex</artifactId>
<version>2.1.3.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.javassist/javassist -->
<dependency>
<groupId>org.javassist</groupId>
<artifactId>javassist</artifactId>
<version>3.24.0-GA</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.activation/javax.activation-api -->
<dependency>
<groupId>javax.activation</groupId>
<artifactId>javax.activation-api</artifactId>
<version>1.2.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.persistence/javax.persistence-api -->
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>javax.persistence-api</artifactId>
<version>2.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.xml.bind/jaxb-api -->
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.3.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.glassfish.jaxb/jaxb-runtime -->
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.3.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.jboss.logging/jboss-logging -->
<dependency>
<groupId>org.jboss.logging</groupId>
<artifactId>jboss-logging</artifactId>
<version>3.3.2.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.jboss.spec.javax.transaction/jboss-transaction-api_1.2_spec -->
<dependency>
<groupId>org.jboss.spec.javax.transaction</groupId>
<artifactId>jboss-transaction-api_1.2_spec</artifactId>
<version>1.1.1.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.jvnet.staxex/stax-ex -->
<dependency>
<groupId>org.jvnet.staxex</groupId>
<artifactId>stax-ex</artifactId>
<version>1.8</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.glassfish.jaxb/txw2 -->
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>txw2</artifactId>
<version>2.3.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.8</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.5.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-c3p0 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-c3p0</artifactId>
<version>5.4.22.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.mchange/mchange-commons-java -->
<dependency>
<groupId>com.mchange</groupId>
<artifactId>mchange-commons-java</artifactId>
<version>0.2.15</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-ehcache -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-ehcache</artifactId>
<version>5.4.22.Final</version>
</dependency>
</dependencies>