细小知识点之Hibernate

1.在hibernate中不建议使用一对多的关联关系,因为这种关系在加载的时候效率不高,因为要维护的数据太多。可以考虑多对一,这样加载的时候效率相对较高,相当于一对一的维护。


 2. JDBC hibernate 和 ibatis 在增删改查上的区别

jdbc:手动
  手动写sql
  delete、insert、update要将对象的值一个一个取出传到sql中,不能直接传入一个对象。
  select:返回的是一个resultset,要从ResultSet中一行一行、一个字段一个字段的取出,然后封装到一个对象中,不直接返回一个对象。
 ibatis的特点:半自动化
  sql要手动写
  delete、insert、update:直接传入一个对象
  select:直接返回一个对象   
 hibernate:全自动
  不写sql,自动封装
  delete、insert、update:直接传入一个对象
  select:直接返回一个对象


3.在数据库中条件查询速度很慢的时候,如何优化?
 3.1.建索引
3.2.减少、修改表之间的关联(一对多换多对一等待)
3.3.优化sql,尽量让sql很快定位数据,
不要让sql做全表查询,应该走索引,把数据量大的表排在前面
3.4.简化查询字段,没用的字段不要,已经对返回结果的控制,尽量返回少量数据


4.在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题?
解决方案一,按照Object[]数据取出数据,然后自己组bean
解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 filed1,type2 field2) ,然后在hql里面就可以直接生成这个bean了。


5.session.load()和session.get()的区别
Session.load/get方法均可以根据指定的实体类和id从数据库读取记录,并返回与之对应的实体对象。其区别在于:

如果未能发现符合条件的记录,get方法返回null,而load方法会抛出一个ObjectNotFoundException。
Load方法可返回实体的代理类实例,而get方法永远直接返回实体类。
load方法可以充分利用内部缓存和二级缓存中的现有数据,而get方法则仅仅在内部缓存中进行数据查找,如没有发现对应数据,将越过二级缓存,直接调用SQL完成数据读取。

6. 

Hibernate中Query.list()和Query.iterator()的区别

list():每次直接从数据库中(不会查询缓存)一次性的取出所有结果集,并放入hibernate的缓存中

iterator():先是通过一条语句查出所有数据的id,每次调用iterator.next()的时候,根据id从hibernate的缓存中查询数据,如果有则返回;若没有,从数据库中查询,并放入缓存中,所有运气不好会发出N+1条sql语句。如果数据量很大,效率可想而知。





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值