Hibernate笔试面试题

来源:互联网 发布:淘宝号权重值是什么 编辑:程序博客网 时间:2024/05/16 15:12
1.Hibernate有哪几种查询数据的方式 
      (1)导航对象图查询 
      (2)OID查询 
      (3)HQL 
      (4)QBC 
      (5)本地SQL 
2.load()和get()的区别 
load加载方法: 
Java代码 
Users user = (Users)session.load(Users.class, userId);     
Users user = (Users)session.load(Users.class, userId); 

get加载方法: 
Java代码 
Users user = (Users)session.get(Users.class, userId);   
Users user = (Users)session.get(Users.class, userId); 

两加载方法区别: 
区别1:如果数据库中,没有userId的对象。如果通过get方法加载,则返回的是一个null;如果通过load加载,则返回一个代理对象,如果后面代码如果调用user对象的某个属性(比如user.getPassword())会抛出异常:org.hibernate.ObjectNotFoundException; 
区别2:load支持延迟加载,get不支持延迟加载。 
也就是说: 
Java代码 
Users user = (Users)session.load(Users.class, userId);   
Users user = (Users)session.load(Users.class, userId); 
这句代码不会去执行数据库查询,只有用到user时才会去执行数据库查询。 
而: 
Java代码 
Users user = (Users)session.get(Users.class, userId);   
Users user = (Users)session.get(Users.class, userId); 
则立即去执行数据库查询。 所以Users user = (Users)session.load(Users.class, userId);不会执行任何sql。 

注意: 
Java代码 
Users user = (Users)session.load(Users.class, userId);    
System.out.println(user.getId());   
Users user = (Users)session.load(Users.class, userId); 
System.out.println(user.getId()); 

上面这2句代码,不会去执行数据库操作。因为load后会在hibernate的一级缓存里存放一个map对象,该map的key就是userId的值,但是当你getId()时,它会去一级缓存里拿map的key值,而不去执行数据库查询。所以不会报任何错。不会执行任何数据库操作。 


3.   Hibernate工作原理及为什么要用? 
原理: 
①、读取并解析配置文件 
②、读取并解析映射信息,创建SessionFactory 
③、打开Sesssion 
④、创建事务Transation 
⑤、持久化操作 
⑥、提交事务 
⑦、关闭Session 
⑧、关闭SesstionFactory 

为什么要用?
1. 对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。 
2. Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作 
3. hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。 
4. hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。 

4.   Hibernate是如何延迟加载? 
①、Hibernate2延迟加载实现:a)实体对象  b)集合(Collection) 
②、Hibernate3 提供了属性的延迟加载功能 
当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内存开销,从而提高了服务器的性能。 

5.   Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系) 
类与类之间的关系主要体现在表与表之间的关系进行操作,它们都是对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many、 

5.   说下Hibernate的缓存机制 
①、内部缓存存在Hibernate中又叫一级缓存,属于应用事物级缓存 
②、二级缓存: 

a) 应用及缓存 

b) 分布式缓存 

条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被系统频繁使用、非关键数据 
c)  第三方缓存的实现 

6.   Hibernate的查询方式 

Sql、Criteria,object comptosition 

Hql: 
1、  属性查询 
2、  参数查询、命名参数查询 
3、  关联查询 
4、  分页查询 
5、  统计函数 

7.   如何优化Hibernate? 
1.         使用双向一对多关联,不使用单向一对多 
2.         灵活使用单向一对多关联 
3.         不用一对一,用多对一取代 
4.         配置对象缓存,不使用集合缓存 
5.         一对多集合使用Bag,多对多集合使用Set 
6.         继承类使用显式多态 

7.         表字段要少,表关联不要怕多,有二级缓存撑腰 


=====================Hibernate笔试题========================== 

(1)一般情况下,关系数据模型与对象模型之间有哪些匹配关系(多选) 
A)表对应类 
B)记录对应对象 
C)表的字段对应类的属性 
D)表之间的参考关系对应类之间的依赖关系 

(2)以下关于SessionFactory的说法哪些正确?(多选) 
A)对于每个数据库事务,应该创建一个SessionFactory对象 
B)一个SessionFactory对象对应一个数据库存储源。 
C)SessionFactory是重量级的对象,不应该随意创建。如果系统中只有一个数据库存储源,只需要创建一个。 
D)SessionFactory的load()方法用于加载持久化对象 


(3)Customer类中有一个Set类型的orders属性,用来存放Order订单对象,在Customer.hbm.xml文件中,用哪个元素映射orders属性? 
A)<set> B)<one-to-many> C)<many-to-one> D)<property> 

(4)<set>元素有一个cascade属性,如果希望Hibernate级联保存集合中的对象,casecade属性应该取什么值?(单选) 
A)none 
B)save 
C)delete 
D)save-update 


(5)以下哪些属于Session的方法? 
A)load() 
B)save() 
C)delete() 
D)update() 
E)open() 
F)close() 

(6)以下程序的打印结果是什么?(单选) 

tx = session.beginTransaction(); 
Customer c1=(Customer)session.load(Customer.class,new Long(1)); 
Customer c2=(Customer)session.load(Customer.class,new Long(1)); 
System.out.println(c1==c2); 
tx.commit(); 
session.close(); 

A)运行出错,抛出异常 
B)打印false 
C)打印true 


(7)以下程序代码对Customer的name属性修改了两次: 
tx = session.beginTransaction(); 
Customer customer=(Customer)session.load(Customer.class, new Long(1)); 
customer.setName(\"Jack\"); 
customer.setName(\"Mike\"); 
tx.commit(); 

执行以上程序,Hibernate需要向数据库提交几条update语句?(单选) 
A)0 B)1 C)2 D)3 

(8)在持久化层,对象分为哪些状态?(多选) 
A)临时状态 
B)独立状态 
C)游离状态 
D)持久化状态 

(9)对于以下程序,Customer对象在第几行变为持久化状态?(单选) 
Customer customer=new Customer(); //line1 
customer.setName(\"Tom\"); //line2 
Session session1=sessionFactory.openSession(); //line3 
Transaction tx1 = session1.beginTransaction(); //line4 
session1.save(customer); //line4 
tx1.commit(); //line5 
session1.close(); //line6 

A) line1 B)line2 C)line3 D)line4 E)line5 F)line6 

(10)对于以下程序,Customer对象在第几行变为游离状态?(单选) 
Customer customer=new Customer(); //line1 
customer.setName(\"Tom\"); //line2 
Session session1=sessionFactory.openSession(); //line3 
Transaction tx1 = session1.beginTransaction(); //line4 
session1.save(customer); //line4 
tx1.commit(); //line5 
session1.close(); //line6 

A) line1 B)line2 C)line3 D)line4 E)line5 F)line6 

(11)以下哪一种检索策略利用了外连结查询?(单选) 
A)立即检索 B)延迟检索 C)迫切左外连结检索 

(12)假设对Customer类的orders集合采用延迟检索策略,编译或运行以下程序,会出现什么情况(单选) 
Session session=sessionFactory.openSession(); 
tx = session.beginTransaction(); 
Customer customer=(Customer)session.get(Customer.class,new Long(1)); 
tx.commit(); 
session.close(); 
Iterator orderIterator=customer.getOrders().iterator(); 

A)编译出错 B)编译通过,并正常运行 C)编译通过,但运行时抛出异常 

(13)关于HQL与SQL,以下哪些说法正确?(多选) 
A)HQL与SQL没什么差别 
B)HQL面向对象,而SQL操纵关系数据库 
C)在HQL与SQL中,都包含select,insert,update,delete语句 
D)HQL仅用于查询数据,不支持insert,update和delete语句 

(14)事务隔离级别是由谁实现的?(单选) 
A)Java应用程序 B)Hibernate C)数据库系统 D)JDBC驱动程序 

(15)悲观锁与乐观锁,哪个具有较好的并发性能?(单选) 
A)悲观锁 B)乐观锁 

答案: 
(1)A,B,C (2)B,C (3)A (4)D (5)A,B,C,D,F (6)C (7)B (8)A,C,D (9)D   (10)F (11)C (12)C (13)B,D (14)C (15)B 
0 0
原创粉丝点击