初识hibernate 2

来源:互联网 发布:淘宝造物节线上活动 编辑:程序博客网 时间:2024/05/28 05:18

1.hibernate 对象状态

 瞬时态  : new 的对象  和session关联之前                                           瞬时态  和数据库没什么关系

 持久态 :  跟Session 关联的对象,受Session管理的对象             

持久化对象:该对象和数据通着气的对象,通过操作持久化对象可以操作数据库        操作瞬时/游离态 不能同步更新数据库

通过HQL查出的对象也是持久化对象

     变持久的方法: save update  delete  get  load    

注意:持久化的对象其属性值改变后,在事务提交的时候会自动更新数据库

脏检查 :在事务提交事务时候,hibernate会对持久化对象的属性值进行检查,一旦其属性值发生改变,会自动发送sql到数据库,对数据库进行更新

 游离态脱离的方法:   session.evict(数据库表明)           session.close();     session.clear();  注意:游离态并不表示对象已被垃圾回收站回收

   

游离态:和session脱离关联的对象  ,但是该对象还存在OID(Object  id:改对象对应数据库记录的主键)

游离态和瞬时态的区别:游离态的对象有OID,瞬时态是还未被处理的对象             一般面试会提到  

游离态----->持久态:  session.saveOrUpdate(数据库表明) 重新恢复为持久态

持久态---->游离态:  session.evict(数据库表明)  

                            session.close();  

 session.clear()   

瞬时态--->持久态:   save   update    delete    get     load     

hibernate 单表查询:

主键查询:

 get :如果该主键不存在,返回null,不会抛出异常(其实可能下一行会抛出异常,比较坑)

 load:如果该主键不存在,抛出异常 ObjectNotFoundException    


查询一个表中的所有数据

HQL:Hibernate Query  Language   查询语句

HQL是基于对象的,不能写表名,把sql中的表名替换成类名


select * from panda - 替换为--- from Panda

 select  fur_color  from panda    ----- 替换为-select  furColor  from Panda  把列名替换成属性名

Query

 QuerySyntaxException:HQL语句错误 

JavaBean规范(通过那个属性对数据库进行操作就对那个属性进行封装 ) 单独创建一个人QueryBean文件 query 查询
1.属性都是private,并且添加无参有参构造方法 
2.添加无参构造
3.实现Serializable 接口

投影查询:查询部分列 
1.List<Object[]>

2,List<类名>:HQL : 类名 (要查询的列名)

该类中必须有对应的构造     重点使用频繁    可以查所有

1.List<Map>

1. 增删改操作:
1.先查出持久化对象  get load

2.session.delete()/update()

提交事务


2 通过HQL进行修改操作

1.编写 HQL

2.获取Query

3.query.executeUpdate():受影响的记录数



HQL条件查询方式:

1. ?  :setXXX(下标,值) 注意下标从0开始 

 setParameter(下标,值)

2.参数名  

setParameter("参数名","参数值");

setProperties(Map/JavaBean)

注意属性名要和HQL中参数名一致 


 



原创粉丝点击