大连接数时,就不会再创建新的连接对象了。如果连接池当中的数量大于初始创建的连接数,并且有空闲的连接,那么这些空闲连接在闲置一段时间之后就会被销毁。初始创建的连接数量,最大连接数和连接空闲的时间都可以通过配置文件来指定。在hibernate和Spring当中都可以配置连接池,我最常用的连接池是DBCP和C3P0。
常见面试题七--Statement和PreparedStatement有什么区别?哪个效率高?
回答Statement和PreparedStatement都是用于执行SQL语句的句柄,但是PreparedStatement代表的是一个预编译的SQL。这两种对象的区别主要体现在以下的三个方面:
第一是使用方面的区别,statement执行的SQL语句必须是一个完整的SQL,而对于PreparedStatement来说,可以使用“?”作为SQL语句当中的占位符,然后使用PreparedStatement的setXXX方法来给占位符赋值,最后在执行;
第二个区别是使用Statement时,如果SQL当中出现了“‘”或者“-”等符号时,需要使用转义字符来进行转义,而在PreparedStatement当中,如果占位符的值当中有这些符号,PreparedStatement会自动的进行转义;
最后一个区别是PreparedStatement会讲SQL语句进行预编译,每次执行的时候只需要将参数设置给相应的占位符就可以运行。而使用Statement时,SQL语句时每次都要进行编译,所以PreparedStatement的效率相对较高。
常见面试题九--请简述你对MVC模式的理解
回答:MVC模式是表示层开发最常用的设计模式,使用这个
设计模式的目的是为了解除控制逻辑,业务逻辑和视图之间的耦合,提升系统的可扩展性和可维护性。
MVC模式主要由模型,控制器和视图三个部分组成。其中控制器的主要责任是接受客户所提交的请求,并将请求转发给适当的模型对象进行处理,再将
处理的结果发给视图,进行显示。在J2EE项目当中,通常会使用Servlet来担任这个角色,因为在Servlet当中可以直接使用HttpServletRequest,HttpServletResponse等API。模型的主要作用是根据客户的请求来进行相应的业务运算,这个部分的功能在J2EE当中主要使用JavaBean来完成,这部分的代码不能依赖于Servlet API,从而可以保证业务逻辑的可移植性。控制器将模型运算的结果发送到视图,视图负责将这部分数据显示给客户。这个部分的功能在J2EE当中主要是使用
JSP来完成。因为JSP可以在允许在
HTML当中插入
Java代码。
常见面试题十二--请简述Hibernate的有缺点
Hibernate是一种ORM框架,可以帮助
程序员方便的实现透明的持久化操作,它的优点主要有以下的几个方面:
1. Hibernate实现了基于POJO的持久化操作,框架对于POJO完全没有侵入,因此程序员完全不需要关机对象持久化的细节,从而提升了开发效率;
2. Hibernte提供了HQL和QBC作为查询工具,而不是使用传统的SQL,这两种
查询方法都提供了丰富的面向对象机制,缓解了
系统的阻抗不匹配
问题 3. 操作数据据的SQL由Hibernate根据hibernate.cfg.xml我呢件当中所指定的数据库方言生成,方便应用程序在不同的数据库之间移植;
4. Hibernate当中内置了一级和二级缓存,提升了操作数据库的性能;
Hibernate在拥有以上优点的同时,也避免不了ORM框架的通病。如N+1问题,也就是使用类似于select from User u这样的HQL语句查询时,如果数据库当中有N条数据,Hibernate就需要运行N+1条SQL语句,这大大影响了系统的姓能。另外Hiberante的映射文件的编写也显得比较繁琐,容易出错