我们先来看一个比较常见的hibernate.cfg.xml配置文件:
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/hibernate
root
root
org.hibernate.dialect.MySQLDialect
true
true
create
hibernate
thread
对于前四个属性我们或许比较熟悉,因为我们过去写的连接数据库的代码会经常遇到,我们不再介绍。
接着来看其他比较重要的属性:
hibernate.dialect表示连接数据库的方言机制,这个最好理解的例子就是MySQL和Oracle实现分页的原理不同
的,使用的代码也是不同的。这个以后用到了再进行解释。
hibernate.default_schema表示生成数据表的时候会在表名前加入hibernate前缀;指的是默认数据库
hibernate中的数据表students。这里设置的值需要和使用的数据库的名字保持一致。
hibernate.show_sql表示向控制台输出SQL语句;
hibernate.format_sql表示格式化输出到控制台的SQL语句;
对于这几个属性我们可以演示一个例子:
数据库显示:
hibernate.hbm2ddl.auto属性四个值解释:
create:表示启动的时候先drop,再create,每次重新生成表结构
create-drop: 也表示创建,只不过再系统关闭前执行一下drop
update: 这个操作启动的时候会去检查schema是否一致,如果不一致会做scheme更新,保留原有的数据
validate: 启动时验证现有schema与你配置的hibernate是否一致,如果不一致就抛出异常,并不做更新
在这里我们只演示create和update,刚才上面的情况就是值为create的情况,这里我们改变其值为update:
控制台输出:
数据库显示:
注意:hibernate前缀可以省略,即hibernate.dialect等同于dialect
我们也来看一个比较常用的Students.hbm.xml:
常用配置元素介绍
hibernate-mapping元素可以包含的子元素
class – 描述被映射的类
subclass/joined-subclass – 在继承关系的映射中会用到
query – 将查询语句定义在配置文件中
hibernate-mapping元素的常用属性:
class元素可以包含的常见子元素:
id – 主键定义
property – 属性定义
关系映射定义(一对多、多对一等)
class元素常用属性:
实体类的类名
table="tableName" //被映射到数据库表的名称
batch-size="N" //抓举策略
where="condition"
entity="EntityName"
/>
被映射的类必须要有一个id定义,通常使用逻辑主键。逻辑主键是没有意义的唯一标识符;而业务主键:有意义
的唯一标识符。
Hibernate使用generator类来生成主键,Hibernate自带了很多generator(不同的主键生成策略),比如:
int/long – native或String - uuid等。我们也可以定义自己的generator实现IdentifierGenerator接口一般情况下不
需要实现自己的generator。
id元素常用属性及子元素:
//主键生成策略
generator是主键生成器,每个主键都必须定义相应的主键生成策略。它用来为持久化类实例生成唯一的标识。
Hibernate内置的主键生成策略表:
可使用的常见属性如下:
name – 对应类的属性名称
type – 指定属性的类型,一般情况下可以不用指定,由hibernate自动匹配(可参考文档中的有关说明)
length – 指定长度
column – 指定属性所对应的数据库字段的名称,如果不指定,就是属性的名称
如果安装了Hibernate插件,那么可以在实体类上右击新建对象关系映射配置文件,Eclipse可以自动生成,那么
我们可以看看自动生成的对象关系映射配置文件是怎样的:
操作步骤:
第一步:
第二步:
第三步:
第四步:
最后生成的Students.hbm.xml配置文件: