2022年Hibernate常见面试题汇总 .pdf
《2022年Hibernate常见面试题汇总 .pdf》由会员分享,可在线阅读,更多相关《2022年Hibernate常见面试题汇总 .pdf(4页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1.在数据库中条件查询速度很慢的时候,如何优化 ? 1.建索引2.减少表之间的关联3.优化 sql,尽量让sql 很快定位数据,不要让sql 做全表查询,应该走索引,把数据量大的表排在前面4.简化查询字段,没用的字段不要,已经对返回结果的控制,尽量返回少量数据2.在 Hibernate 中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题? 解决方案一,按照Object 数据取出数据,然后自己组bean 解决方案二,对每个表的bean 写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 f
2、iled1,type2 field2) ,然后在hql 里面就可以直接生成这个 bean 了。具体怎么用请看相关文档,我说的不是很清楚。session.load()和 session.get() 的区别Session.load/get方法均可以根据指定的实体类和id 从数据库读取记录, 并返回与之对应的实体对象。其区别在于:如果未能发现符合条件的记录,get 方法返回 null ,而 load 方法会抛出一个ObjectNotFoundException。Load 方法可返回实体的代理类实例,而get 方法永远直接返回实体类。load 方法可以充分利用内部缓存和二级缓存中的现有数据,而 get
3、 方法则仅仅在内部缓存中进行数据查找,如没有发现对应数据,将越过二级缓存,直接调用SQL 完成数据读取。Session 在加载实体对象时,将经过的过程:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 4 页 - - - - - - - - - 首先, Hibernate中维持了两级缓存。第一级缓存由Session 实例维护,其中保持了Session 当前所有关联实体的数据,也称为内部缓存。而第二级缓存则存在于SessionFactory 层次,由当前所有由本Session
4、Factory构造的 Session实例共享。出于性能考虑,避免无谓的数据库访问,Session 在调用数据库查询功能之前,会先在缓存中进行查询。首先在第一级缓存中,通过实体类型和id 进行查找,如果第一级缓存查找命中,且数据状态合法,则直接返回。之后,Session会在当前 “NonExists ”记录中进行查找,如果“NonExists ”记录中存在同样的查询条件,则返回 null。“NonExists ”记录了当前Session 实例在之前所有查询操作中,未能查询到有效数据的查询条件(相当于一个查询黑名单列表)。如此一来,如果Session中一个无效的查询条件重复出现,即可迅速作出判断,
5、从而获得最佳的性能表现。对于 load 方法而言,如果内部缓存中未发现有效数据,则查询第二级缓存,如果第二级缓存命中,则返回。如在缓存中未发现有效数据,则发起数据库查询操作(Select SQL ),如经过查询未发现对应记录,则将此次查询的信息在“NonExists ”中加以记录,并返回null 。根据映射配置和Select SQL 得到的 ResultSet ,创建对应的数据对象。将其数据对象纳入当前Session实体管理容器(一级缓存)。执行 Interceptor.onLoad方法(如果有对应的Interceptor )。将数据对象纳入二级缓存。如果数据对象实现了LifeCycle接口,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年Hibernate常见面试题汇总 2022 Hibernate 常见 试题 汇总
限制150内