1.导包
- Hibernate开发包
-
- 数据库的驱动包
2.核心配置文件
核心配置文件(赋值到src下)
1.核心配置文件
对于hibernate的核心配置文件它有两种方式(选其中一种即可):
- hibernate.cfg.xml
- hibernate.properties
我们在开发中使用比较多的是hibernate.cfg.xml这种方式,原因它的配置能力更强,易于修改
我们主要讲解的是hibernate.cfg.xml配置
1.可以加载数据库相关信息
<!-- 配置关于数据库连接的四个项 driverClass url username password -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///hibernateTest</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123</property>
2.hibernate相关配置
<!-- 可以将向数据库发送的sql显示出来 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式化sql -->
<property name="hibernate.format_sql">true</property>
<!-- hibernate的方言(告知链接的数据库类型MySQL为例) -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
3.加载映射配置文件
<!-- 配置hibernate的映射文件所在位置 -->
<mapping resource="cn/itheima/domain/Customer.hbm.xml" />
对于hibernate.cfg.xml配置文件中的内容可以参考hibernate/project/etc/hibernate.properties的配置
配置下面这些属性后,我们可以进行表的自动创建
#hibernate.hbm2ddl.auto create-drop
#hibernate.hbm2ddl.auto create
#hibernate.hbm2ddl.auto update
#hibernate.hbm2ddl.auto validate
Create-drop 每次都会创建一个新的表,执行完成后删除。一般在测试中使用
Create 每次都会创建一个新的表,一般是在测试中使用
update 如果数据库中有表,不创建,没有表创建,如果映射不匹配,会自动更新表结构(只能添加)
validate 只会使用存在的表,并且会对映射关系进行校验.
3.映射配置文件
它一般放置在实体类所在的包下。
这个配置文件的主要作用是建立表与类的映射关系。
1.统一声明包名,这样在<class>中就不需要写类的全名.
2.关于<class>标签配置
2.关于<class>标签配置
<class name="cn.itcast.domain.Customer" table="t_coustomer" catalog="hibernateTest">
<id></id>
</class>
name属性:类的全名称
table 表的名称,可以省略,这时表的名称就与类名一致
catalog属性:数据库名称 可以省略.如果省略,参考核心配置文件中url路径中的库名称
3.关于<id>标签
<!-- id用于描述主键 -->
<id name="id" column="id">
<!-- 主键生成策略 -->
<generator class="native"></generator>
</id>
首先它必须存在。<id>是用于建立类中的属性与表中的主键映射。
name 类中的属性名称
column 表中的主键名称 column它也可以省略,这时列名就与类中属性名称一致
length 字段长度
type属性 指定类型
<generator>它主要是描述主键生成策略.
4.关于<property>标签
<!-- 使用property来描述属性与字段的对应关系 -->
<property name="name" column="name" length="20"></property>
<property name="address" column="address" length="50"></property>
关于hibernate的映射文件中类型问题
对于type属性它的取值,可以有三种:
1.java中的数据类型
2.hibernate中的数据类型
3.SQL的数据类型
默认是hibernate中数据类型
4.获取session的工具类编写(可选)
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
/**
* HibernateUtils工具类
*
* @author TGV5
*
*/
public class HibernateUtils {
private static Configuration config;
private static SessionFactory sessionFactory;
static {
config = new Configuration().configure();
sessionFactory = config.buildSessionFactory();
}
/**
* 获取SessionFactory
*
* @return
*/
public static Session openSession() {
return sessionFactory.openSession();
}
public static Session getCurrentSession() {
return sessionFactory.getCurrentSession();
}
}
5.c3p0连接池的配置(虽然HIbernate带有默认的连接池,但是性能不如C3P0连接池)
1.导入Hibernate提供的3个C3p0的jar包
2.在核心配置文件hibernate.cfg.xml中添加提供者配置
c3p0的配置的可以不进行配置,会有默认的配置
<!-- 设置连接提供者 -->
<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<!-- c3p0连接池的配置 -->
<property name="hibernate.c3p0.max_size">20</property><!-- 最大连接池 -->
<property name="hibernate.c3p0.min_size">5</property><!-- 最小连接数 -->
<property name="hibernate.c3p0.timeout">120</property> <!-- 超时 -->
<property name="hibernate.c3p0.idle_test_period">3000</property> <!-- 空闲连接 -->
附件列表