Hibernate(two)

//////////2016-12-14 ~ 2016-12-15///////////

int study_data(){

配置实体映射:

1.xml:

配置文件名字:类名.hbm.xml

   

       

       

        ...

   

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()

你可能感兴趣的:(Hibernate(two))