01 Hibernate错题分析

 

解析:

此题目考查的是对Hibernate中交叉连接的理解。HQL支持SQL风格的交叉连接查询,交叉连接适用于两个类之间没有定义任何关联时。
在where字句中,通过属性作为筛选条件,如统计报表数据。使用交叉连接时应避免“from Dept,Emp”这样的语句出现。执行这条HQL
查询语句,返回DEPT表和EMP表的交叉组合,结果集的记录数为两个表的记录数之积,也就是数据库中的笛卡尔积。这样的查询结果没有
实际意义,因此选项b是正确的。A和C答案都是符合上述描述的,是适合使用交叉连接的场合。D答案认为以上三种都适合,与上述描述冲
突。由于题目要求选择不适合使用交叉连接的选项,因此选项B、C、D是错误的。

解析:第二次查询要说明是从缓存中查询

解析:
答案A中,HQL的select语句中的类名和属性名是区分大小写的;答案B中,HQL是支持统计函数的;
答案D中,绑定参数的序号从0开始。所以ABD都不正确,只有C是正确的。因此答案是c。



解析:

B答案不是hibernate中list方法返回结果的正确类型,list方法只会返回List集合类型,因此选项B是错误的。
C和D答案是迷惑选项,因为HQL语句中对Dept部门和d.emps部门员工进行了连接查询,查询结果中同时包括Dept
和d.emps的属性,它们既不会被造型为Dept,也不会被造型为Emp,因此选项C和D是错误的。A答案返回的是List
类型,同时指定List的泛型为Object[],数组中第一个元素是Dept类型,包含Dept的属性集。数组中第二个元素
是Emp类型,包含Emp的属性集,因此选项A是正确的。


解析:
因为没有center join语法,所以C错;
因为题目是用cross join,所以AB错

解析:one-to-one配置的查询,必须查询到另一个实体

解析:经常被修改的数据需要一级缓存存储,而二级缓存存储查询的数据和常量数据。财务数据存储一些重要的数据,
不只是需要简单的查询,需要修改,所以需要用一级缓存进行存储。

解析:Session为一级缓存,SessionFactory为二级缓存

解析:
学员应注意二级缓存使用的要求。二级缓存使用时,经常被修改的数据不适用与放入二级缓存,因此A不正确;
在多个应用之间共享的数据也不适合加入二级缓存,因为Hibernate不能自动保证在一个应用修改其中数据后
缓存数据会与数据库保持一致,因此B不正确。

解析:
因为如 A right join B 即取出B表的所有数据,由on条件关联的A表数据,有则显示,没有则为空;所以B错;

解析:
 inner join [fetch]为内连接的语法,left [outer] join 为左外连接的语法,right [outer] join为右外连接的语法,[inner] join fetch为迫切内连接的语法,所以本题正确选项是C。


解析:

本题考查的是HQL内连接与迫切内连接的区别。选项A的说法不正确,因为只有迫切内连接才会立即加载连接数据,普通内连接在初始化时set集合并不会立即加载数据。
选项B的说法是正确的,emps集合不会被初始化。选项C的说法也是正确的,第二句是迫切内连接,所以数据会立即加载。选项D是误导选项。


解析:

本题中唯一错误的选项为D,因为fetch只对inner join 和left join有效,对right join无效。

解析:
在HQL查询语句中,如果通过对Emp类赋别名“e”,可以通过e.dept.dname的形式访问dept对象的dname属性,
使用隐式内连接按部门条件查询员工信息,因此选项B是正确的。另外也可以显式使用inner join关键字内连接
e.dept对象,因此选项C也是正确的。A答案中虽然使用了inner join关键字,但是连接对象使用不正确,这样
做会导致“could not found the property Dept of Emp”的错误,即在Emp类中找不到叫作Dept的属性。
原因是Hibernate是一款基于ORM的解决方案,在HQL语句执行之前已经对表和持久化对象作了映射,Hibernate
只知道Emp中有dept属性,而不知道Dept,因此选项A是错误的。B答案是照搬SQL语句的写法,该写法用在HQL中
会导致将“研发部”这个部门对象与每一个Emp员工对象匹配的结果,总记录数等于Emp员工的记录数,因此选项B是错误的。

解析:
对于经常使用的查询语句,如果启用了查询缓存,当第一次执行查询语句时,Hibernate会把查询结果存放在第二缓存中。以后再次执行该查询语句时,
只需从缓存中获得查询结果,从而提高查询性能。所以本题正确选项是AB。

解析:
在HQL迫切连接中,fetch关键字只对inner join和left join有效。对于right join而言,
由于作为关联对象容器的“左边”对象可能为null,所以也就无法通过fetch关键字强制Hibernate
进行集合填充操作,因此选项a是正确的。B答案是将fetch用在迫切左外连接的正确用法。C答案是
将fetch用在显示迫切内连接的正确用法。D答案是将fetch用在隐示迫切内连接的正确用法。由于
题目要求选择用法不正确的选项,因此选项B、C、D是错误的。

解析:
A一级缓存和二级缓存能进行交互,需要配置 关闭二级缓存
B 没有此配法
C 可以在相应的映射进行配置
D 正确

解析:
执行from Dept d inner join d.emps返回的集合中,每个元素是一个Object[ ];
执行from Dept d inner join fetch d.emps返回的集合中,每个元素是一个Dept对象。
执行from Dept d inner join d.emps所得到的Dept对象中的emps属性是未初始化,即
没有存储关联的Emp对象;执行from Dept d inner join fetch d.emps所得到的Dept
对象中的emps属性才是初始化好的。

解析:B、数据库可以永久保存数据,而且有访问权限,可以保证数据的安全性。
D、添加事务操作才能对数据进行操作,锁主要用于多用户环境下保证数据库完整性和一致性。

hibernate错题解析的更多相关文章

  1. 01 Hibernate错题分析

    解析: 此题目考查的是对Hibernate中交叉连接的理解.HQL支持SQL风格的交叉连接查询,交叉连接适用于两个类之间没有定义任何关联时.在where字句中,通过属性作为筛选条件,如统计报表数据.使 ...

  2. Hibernate第三次测试错题解析

    此题目考查的是Hibernate查询缓存适用的场合,对于经常使用的查询语句, 如果启用了查询缓存,当第一次执行查询语句时,Hibernate会把查询结果存放在第二缓存中. 以后再次执行该查询语句时,只 ...

  3. 03 Hibernate错题分析

    1.在Hibernate中,以下关于主键生成器说法错误的是( C). A.increment可以用于类型为long.short或byte的主键 B.identity用于如SQL Server.DB2. ...

  4. 02 Hibernate错题分析

    解析:使用final修饰的成员变量是常量 解析:不存在StateMoreSession的对象 解析:一个PreparedStatement 可以执行多次executQuery方法 解析:A   使用H ...

  5. Java五道输出易错题解析(避免小错误)

    收集了几个易错的或好玩的Java输出题,分享给大家,以后在编程学习中稍微注意下就OK了. 1. 看不见的空格? 下面的输出会正常吗? package basic; public class Integ ...

  6. Java五道输出易错题解析(进来挑战下)

    转自:http://blog.csdn.net/lanxuezaipiao/article/details/41985243 收集了几个易错的或好玩的Java输出题,分享给大家,以后在编程学习中稍微注 ...

  7. UI测试_错题解析

    解析:因为jQuery easyUI是基于jQuery框架在使用之前应该先引入jquery框架否则jQuery easyUI将失效,故D错误 解析:考Link标签和script标签的区别,Link引入 ...

  8. SSM自测错题解析

    试题解析:spring 中bean的作用域有:singleton.session.prototype.request.global Session 试题解析:使用import导入子元素需要用prope ...

  9. struts2 测试错题解析

    解析:$.parseJSON()方法是将字符串转换成Json类型数据,$.getJSON()方法是获取JSON数据,两者不用联合使用. 解析: A:ActionContext接口没有getReques ...

随机推荐

  1. php增删改查,自己写的demo

    1.链接数据库通用方法:conn.php <?php //第一步:链接数据库 $conn=@mysql_connect("localhost:3306","root ...

  2. java byte 16进制转换

    整型转16进制: int devIdInt = Integer.parseInt(devId);String devIdString = Integer.toHexString(devIdInt); ...

  3. springmvc入门详解

    首先,我们先写一个入门小案例,先熟悉一下springmvc是什么,了解一下springmvc的运行流程,对加强springmvc的深层理解有很大帮助 .第一步,创建一个maven项目: <?xm ...

  4. js操作符

    JS操作符 x + y(数字) 将x和y相加; x + y(字符串) 将x和y拼接在一起; x - y 从x中减去y; x * y 将x和y相乘; x / y 将x除以y; x % y x和y的模(既 ...

  5. UIImageView中最容易用错的属性UIContentMode小记

    UIContentMode这东西初学真是各种问题,只能不断尝试,偶然发现网上这张图片,做下记录 还有个UIViewContentModeRedraw,在使用这个设置后,每当图片的bounds就是大小或 ...

  6. C#操作EXCEL的时候出现“ 无法将类型为“Microsoft.Office.Interop.Excel.ApplicationClass”的COM 对象强制转换为接口类型“Microsoft.Office.Interop.Excel._Application” ”问题

    总是报出这个错误,准备放弃COM的组件转投NPOI,后来想起在装这个操作系统的时候,自带装过WPS,后来使用360卸载了.于是想着试一试的心态,重新安装了WPS,结果,问题解决了.你懂的.

  7. java基础学习----String

    旨在从内存方面看String类的知识点: 1.为何不能被继承(final类) 2.字符拼接时,String类的内存分配问题. 3.String的intern()方法 关于String类经常出现的面试题 ...

  8. LIS n*log(n)的理解

    很多时候lis 用二分的方法比较方便 这里写一下他的原理 这里仅对严格的最长上升子序列做讨论 这里有两个数列  一个数列是 原串的数列 a1-an  另一个数列是最长上升子序列辅助数列 s数列的长度为 ...

  9. js禁止默认的右键菜单或出现自定义右键菜单

    1.屏蔽默认的右键菜单 js: document.getElementById('myimg').oncontextmenu=function(){return false;} jquery: $(' ...

  10. 神奇的match和replace

    源自跟奈落大叔的讨论,PHP和JavaScript的比较. 正则: 先说几个正则写法: () 选择匹配一组, (?:) 降低 () 的优先级, .*? 和 .+? ,阻止 . 和 + 的贪婪. 还有一 ...