读书人

Hibernate 配备 说明

发布时间: 2012-09-18 16:21:42 作者: rapoo

Hibernate 配置 说明

Hibernate配置说明

?

<?xml version="1.0" encoding="utf-8"?><!DOCTYPE hibernate-configuration    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"><hibernate-configuration>    <session-factory >        <!-- 启动服务器时,自动更新数据库.开发结束以后,删掉下面这行--><property name="hibernate.hbm2ddl.auto">update</property><!-- JDBC数据库连接的URL --><property name="hibernate.connection.url">jdbc:mysql://localhost:3306/databasename?characterEncoding=UTF-8</property><!-- JDBC驱动类 --><property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property><!-- 用户名 --><property name="hibernate.connection.username">root</property><!-- 密码 --><property name="hibernate.connection.password">123456</property><!-- Hibernate数据库方言 -->        <property name="dialect">org.hibernate.dialect.MySQLDialect</property><!-- 是否显示SQL语句 -->        <property name="hibernate.show_sql">false</property>                        <!-- 配置数据库连接池 -->        <!-- Hibernate连接池类名 -->        <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>        <!-- 最大连接数 -->        <property name="hibernate.c3p0.max_size">100</property>        <!-- 最小连接数 -->        <property name="hibernate.c3p0.min_size">10</property>        <!-- 获得连接的超时时间,如果超过这个时间,会抛出异常,单位秒 -->        <property name="hibernate.c3p0.timeout">120</property>        <!-- 最大的预编译语句的数量 -->        <property name="hibernate.c3p0.max_statements">50</property>        <!-- 每隔多少秒检查连接池里的空闲连接 ,单位是秒-->        <property name="hibernate.c3p0.idle_test_period">120</property>        <!-- 当连接池里面的连接用完的时候,C3P0一下获取的新的连接数 -->        <property name="hibernate.c3p0.acquire_increment">2</property>        <!-- 每次都验证连接是否可用 -->        <property name="hibernate.c3p0.validate">true</property>                        <!-- 指定的映射类 -->        <mapping name="code"><?xml version="1.0" encoding="utf-8"?><!DOCTYPE hibernate-configuration    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
?

?

接下来就是如何配置Hibernate了,Hibernate的配置文件都放在下面标签内

?

<hibernate-configuration>    <session-factory >    <!-- 配置文件内容-->    </session-factory>    </hibernate-configuration>
?

下面的才是重点:

?

?

?

<!-- 启动服务器时,自动更新数据库,不过MySQL或其它数据库中要有你自己创建的数据库名,里面可以没有表.开发结束以后,可以去掉这个属性-->

<!-- 这里有这样4个值可选:update create create-drop?validate,个人建议用update

validate?????????????? 加载hibernate时,验证创建数据库表结构
create????????????????? 每次加载hibernate,重新创建数据库表结构,这就是导致数据库表数据丢失的原因。
create-drop??????? 加载hibernate时创建,退出是删除表结构
update???????????????? 加载hibernate自动更新数据库结构,但不会删除原有数据

-->

<property name="hibernate.hbm2ddl.auto">update</property>
?

<!-- JDBC数据库连接的URL -->

<!--

MySQL数据库URL:jdbc:mysql:// ip:port/databasename ,port默认为3306

Oracle 数据库URL:jdbc:oracle:thin:@ip:port:databasename,port默认为1521

SQL Server数据库URL:?jdbc:microsoft:sqlserver://ip:port;DatabaseName=databasename ,port默认为1433

如果数据库是在远程电脑,则将localhost换为对应的IP地址;

将databasename换成对应的数据库名;

编码方式根据数据库的编码设置,数据库的编码方式是什么,就改为什么

-->

 <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/databasename?characterEncoding=UTF-8</property>
?

<!-- JDBC驱动类 -->

<!--

至于需要添加的jar包,自己百度下面的驱动类名,就可以找到了

MySQL 数据库驱动:com.mysql.jdbc.Driver?

SQL Server 数据库驱动:?com.microsoft.jdbc.sqlserver.SQLServerDriver

Oracle 数据库驱动:oracle.jdbc.driver.OracleDriver

-->

<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
?

<!-- 用户名 -->

<!--

MySQL数据库默认用户名是 root

Oracle数据库默认用户名为 sysdba

SQL Server 数据库默认用户名为 sa

-->

<property name="hibernate.connection.username">root</property>
?

<!-- 密码 -->

<property name="hibernate.connection.password">123456</property>
?

<!-- Hibernate数据库方言 -->

<!--?

?

MySQL数据库方言为?org.hibernate.dialect.MySQLDialect

Oracle9i/10g 数据库方言为 org.hibernate.dialect.Oracle9Dialect

SQL Server 数据库方言为 org.hibernate.dialect.SQLServerDialect

-->

<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
?

<!-- 是否在控制台显示SQL语句 ,方便调试。开发过程可以设为true,开发结束以后设为false-->

<!--?

允许的值为true 和 false

-->

<property name="hibernate.show_sql">false</property>
?

?<!-- 配置数据库连接池 ,,默认情况下(即没有配置连接池的情况下),Hibernate会采用内建的连接池。但这个连接池性能不佳,且存在诸多BUG。Hibernate支持第三方的连接池,官方推荐的连接池是C3P0,Proxool-->

<!-- Hibernate连接池类名,我现在用的是C3P0 -->

<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
?

<!-- 最大连接数 -->

<property name="hibernate.c3p0.max_size">100</property>

<!-- 最小连接数 -->

<property name="hibernate.c3p0.min_size">10</property>

<!-- 获得连接的超时时间,如果超过这个时间,会抛出异常,单位秒 -->

<property name="hibernate.c3p0.timeout">120</property>

<!-- 最大的预编译语句的数量 -->

<property name="hibernate.c3p0.max_statements">50</property>

?<!-- 每隔多少秒检查连接池里的空闲连接 ,单位是秒-->

<property name="hibernate.c3p0.idle_test_period">120</property>

<!-- 当连接池里面的连接用完的时候,C3P0一下获取的新的连接数 -->

<property name="hibernate.c3p0.acquire_increment">2</property>

<!-- 每次都验证连接是否可用,允许值true,false -->

<property name="hibernate.c3p0.validate">true</property>       
?

<!-- 指定的映射-->

<!--

映射通常有两种形式,一种是<mapping?resource="com/mycom/entity/User.hbm.xml"/>,这种形式是通过映射文件来处理映射关系的,笔者的建议是,如果你想通过数据库生成java类,那么你就用这种方式。直接利用HibernateSychronizer插件来生成。否则的话,配置xml文件极为繁琐,而且当变动数据库模型的时候,有可能出错

一种是?<mapping name="code"><mapping class="com.mycom.entity.User"/><mapping class="com.mycom.entity.Role"/><!--<mapping resource="com/mycom/entity/User.hbm.xml"/><mapping resource="com/mycom/entity/User.hbm.xml"/>-->?

?

?

http://titanseason.iteye.com/blog/1279187

读书人网 >其他相关

热点推荐