//////////2016-12-14 ~ 2016-12-15///////////
int study_data(){
配置实体映射:
1.xml:
配置文件名字:类名.hbm.xml
<hibernate-mapping>
<class name="className" table="tableName">
<id name="类属性名" column="主键名" />
<property name="属性名" column="字段名" />
...
</class>
</hibernate-mapping>
2.annotation:
@Entity //注解Entity表示该类纳入Hibernate管理,能够被持久化,加在实体类前面
@Table(name="tableName") //指定该实体类对应的数据库表名,加在实体类前面
@Id //指定该列为主键。
@Column(name="变量名") //指定变量对应的数据库表的列为"变量名"
hibernate主键策略
assigned - 主键由外部程序负责生成
increment - 由hibernate从数据库中取出主键的最大值,每次增量为1,在内存中生成主键
hilo - 高地位方式,最常用的一种生成方式。需要一张额外的表保存hi的值
seqhilo - 将hilo中的数据表换成了序列sequence,适用于支持sequence的数据库(mysql中不支持sequence)
sequence - 采用数据库提供的sequence机制生成主键,需要数据库支持sequence
identity - 由数据库自己生成,但这个主键必须设置为自增长
native - 由hibernate根据使用的数据库自行判断采用identity,hilo,sequence其中一种作为主键生成方式
uuid - 指在一台机器上生成的数字
guid - 全球唯一标识符
foreign - 使用另外一个相关联的对象的主键作为该对象的主键。主要用于一对一关系中
select - 使用触发器生成主键,很少用
Hibernate实体查询
session.get(class,id):
1.session缓存中查找是否存在id对应的Object
2.二级缓存中查找是否存在id对应的Object
3.数据库查找,若不存在则返回null
session.load(class,id):
lazy load模式:
1.session缓存查找是否存在id对应的Object
2.不存在则返回实体相应的代理对象(没有实体数据)
3.当使用该代理对象时,再查询二级缓存和数据库(没找到时报错,而不是返回null)
非lazy load模式:和get方法一致。
session.find(class,id):
与get方法相似,已不建议使用
HQL查询
HQL(Hibernate Query Language)的语法和SQL很相似,但是HQL是一种面向对象的查询语句,它的操作对象是类、实例、属性等,而SQL的操作对象是数据表、列等数据库对象。
HQL查询依赖于Query类,每一个Query实例对应一个查询对象,它的执行是通过Session的createQuery()方法来获得的。
Query:
session.creatQuery(HQL)
session.creatQuery(HQL,Class)
session.creatNativeQuery(SQL)
session.creatNativeQuery(SQL,Class)
执行HQL查询的步骤:
1、获得Hibernate Session对象
2、编写HQL语句
3、调用Session的createQuery方法创建查询对象
4、如果HQL语句包含参数,则调用Query的setXxx方法为参数赋值
5、调用Query对象的list等方法返回查询结果。
特点:
关键字不区分大小写
持久类名称及属性区分大小写
支持占位符(:name)
from子句,select子句
Hibernate实体操作:
实体状态:
1.瞬时/临时状态(transient):对象不存在数据库以及session缓存当中
2.持久化状态(persistent):对象存在于数据库以及session缓存当中
3.离线/游离状态(detached):对象存在与数据库但不存在与session缓存当中,即未被session托管
状态转化:
new一个实体时变为临时状态
临时状态->持久化状态:save(obeject),saveOrUpdate(object)
持久化状态->临时状态:delete(object)
持久化状态->游离状态:avict(object),close(object),clear(object)
游离状态->持久化状态:update(object),saveOrUpdate(object),lock(object)
游离状态->临时状态:delete(object)
Hibernate事务管理:
Transaction tx = session.beginTransaction()等同于connection.setAutoCommit(false)
tx.commit()等同于connection.commit()
tx.rollback()等同于connection.rollback()
}