周测2

周测2

1.JDBC访问数据库的基本步骤是什么?

1、JDBC所需的四个参数(user,password,url,driverClass)

(1)user用户名

(2)password密码

(3)URL定义了连接数据库时的协议、子协议、数据源标识。

(4)driverClass连接数据库所需的驱动。

2、加载JDBC驱动程序:
3、创建数据库的连接
4、创建一个preparedStatement
5、执行SQL语句
6、遍历结果集
7、处理异常,关闭JDBC对象资源

​ 操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声
​ 明顺序相反:

1、先关闭requestSet
2、再关闭preparedStatement
3、最后关闭连接对象connection

2.说说preparedStatement和Statement的区别?

1.PreparedStatement:

PreparedStatement是java.sql包下面的一个接口,用来执行SQL语句查询,通过调用connection.preparedStatement(sql)方法可以获得PreparedStatment对象。数据库系统会对sql语句进行预编译处理(如果JDBC驱动支持的话),预处理语句将被预先编译好,这条预编译的sql查询语句能在将来的查询中重用,这样一来,它比Statement对象生成的查询速度更快。

2.Statement

使用 Statement 对象。在对数据库只执行一次性存取的时侯,用 Statement 对象进行处理。PreparedStatement 对象的开销比Statement大,对于一次性操作并不会带来额外的好处。

3.execute,executeQuery,executeUpdate的区别是什么?

execute执行增删改查操作

execute返回的结果是个boolean型,当返回的是true的时候,表明有ResultSet结果集,通常是执行了select操作,当返回的是false时,通常是执行了insert、update、delete等操作。execute通常用于执行不明确的sql语句。

executeQuery执行查询操作

executeQuery返回的是ResultSet结果集,通常是执行了select操作。

executeUpdate执行增删改操作

executeUpdate返回的是int型,表明受影响的行数,通常是执行了insert、update、delete等操作。

4.SQL查询出来的结果分页展示一般怎么做?

select * from tb_house a, tb_house_info b,tb_user c
        where a.house_id = b.house_id and a.user_id = c.user_id and a.is_delete = 0 and a.house_type = 0
        order by a.house_id LIMIT 0,5

每页查询5条

5.forward()与redirect()的区别?

1.forward

request.getRequestDispatcher(“new.jsp”).forward(request, response); //转发到new.jsp

2.redirect

response.sendRedirect(“new.jsp”); //重定向到new.jsp

很明显一个是用request对象调用,一个是用response对象调用,那么,这两者有什么区别呢?

一、数据共享方面

forward:转发页面和转发到的页面可以共享request里面的数据
redirect:不能共享数据

二、地址栏显示方面

forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服务器发送的内容从哪里来的,所以它的地址栏还是原来的地址.
redirect是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址.所以地址栏显示的是新的URL.

三、本质区别

转发是服务器行为,重定向是客户端行为。为什么这样说呢,这就要看两个动作的工作流程:

转发过程:客户浏览器发送http请求—>web服务器接受此请求—>调用内部的一个方法在容器内部完成请求处理和转发动作—>将目标资源 发送给客户;在这里,转发的路径必须是同一个web容器下的url,其不能转向到其他的web路径上去,中间传递的是自己的容器内的request。在客 户浏览器路径栏显示的仍然是其第一次访问的路径,也就是说客户是感觉不到服务器做了转发的。转发行为是浏览器只做了一次访问请求。

重定向过程:客户浏览器发送http请求—>web服务器接受后发送302状态码响应及对应新的location给客户浏览器—>客户浏览器发现 是302响应,则自动再发送一个新的http请求,请求url是新的location地址—>服务器根据此请求寻找资源并发送给客户。在这里 location可以重定向到任意URL,既然是浏览器重新发出了请求,则就没有什么request传递的概念了。在客户浏览器路径栏显示的是其重定向的 路径,客户可以观察到地址的变化的。重定向行为是浏览器做了至少两次的访问请求的。

重定向,其实是两次request:第一次,客户端request A,服务器响应,并response回来,告诉浏览器,你应该去B。这个时候IE可以看到地址变了,而且历史的回退按钮也亮了。重定向可以访问自己web应用以外的资源。在重定向的过程中,传输的信息会被丢失。

6.什么是cookie?Session和cookie有什么区别?

1、Cookie 在客户端(浏览器),Session 在服务器端。

2、Cookie的安全性一般,他人可通过分析存放在本地的Cookie并进行Cookie欺骗。在安全性第一的前提下,选择Session更优。重要交互信息比如权限等就要放在Session中,一般的信息记录放Cookie就好了。

3、单个Cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个Cookie。

4、Session 可以放在 文件、数据库或内存中,比如在使用Node时将Session保存在redis中。由于一定时间内它是保存在服务器上的,当访问增多时,会较大地占用服务器的性能。考虑到减轻服务器性能方面,应当适时使用Cookie。

5、Session 的运行依赖Session ID,而 Session ID 是存在 Cookie 中的,也就是说,如果浏览器禁用了 Cookie,Session 也会失效(但是可以通过其它方式实现,比如在 url 中传递 Session ID)。

6、用户验证这种场合一般会用 Session。因此,维持一个会话的核心就是客户端的唯一标识,即Session ID。

7.使用Spring框架的好处是什么?

1、轻量: Spring 是轻量的,基本的版本大约2MB。
2、控制反转: Spring通过控制反转实现了松散耦合,对象们给出它们的依赖,而不是创建或查找依赖的对象们。
3、面向切面的编程(AOP): Spring支持面向切面的编程,并且把应用业务逻辑和系统服务分开。
4、容器: Spring 包含并管理应用中对象的生命周期和配置。
5、MVC框架: Spring的WEB框架是个精心设计的框架,是Web框架的一个很好的替代品。
6、事务管理: Spring 提供一个持续的事务管理接口,可以扩展到上至本地事务下至全局事务(JTA)。
7、异常处理: Spring 提供方便的API把具体技术相关的异常(比如由JDBC,Hibernate or JDO抛出的)转化为一致的unchecked 异常。

8.final, finally, finalize的区别。

一、final :

1、修饰符(关键字) 如果一个类被声明为final,意味着它不能再派生新的子类,不能作为父类被继承。因此一个类不能及被声明为abstract,又被声明为final的。

2、将变量或方法声明为final,可以保证他们使用中不被改变。被声明为final的变量必须在声明时给定初值,而以后的引用中只能读取,不可修改,被声明为final的方法也同样只能使用,不能重载。

二、finally:

异常处理时提供finally块来执行清楚操作。如果抛出一个异常,那么相匹配的catch语句就会执行,然后控制就会进入finally块,如果有的话。

三、finalize:

GC:自动回收机制

finalize()是在java.lang.Object里定义的,也就是说每一个对象都有这么个方法。这个方法在gc启动,该对象被回收的时候被调用。其实gc可以回收大部分的对象(凡是new出来的对象,gc都能搞定,一般情况下我们又不会用new以外的方式去创建对象),所以一般是不需要程序员去实现finalize的。
特殊情况下,需要程序员实现finalize,当对象被回收的时候释放一些资源,比如:一个socket链接,在对象初始化时创建,整个生命周期内有效,那么就需要实现finalize,关闭这个链接。
  使用finalize还需要注意一个事,调用super.finalize();

一个对象的finalize()方法只会被调用一次,而且finalize()被调用不意味着gc会立即回收该对象,所以有可能调用finalize()后,该对象又不需要被回收了,然后到了真正要被回收的时候,因为前面调用过一次,所以不会调用finalize(),产生问题。 所以,推荐不要使用finalize()方法,它跟析构函数不一样。

9.简单说说Java中的异常处理机制的简单原理和应用。

异常处理机制的简单原理和应用

一、Execption可以分为java标准定义的异常和程序员自定义异常2种

(1)一种是当程序违反了java语规则的时候,JAVA虚拟机就会将发生的错误表示为一个异常.这里语法规则指的是JAVA类库内置的语义检查。

例如 int i = 2 / 0 或者 String str = null;str.length();

(2)另一种情况就是JAVA允许程序员扩展这种语义检查,程序员可以创建自己的异常,并自由选择在何时用throw关键字引发异常。

例如 Exception ex = new Exception(“这是我自定义的异常信息”);throw ex;

所有的异常都是Thowable的子类。

异常处理是与程序执行是并行的。

Try{

    //可能发现异常的语句块

}catch(异常类型,e){

   //发生异常时候的执行语句块

} finnally{

  //不管是否发生异常都执行的语句块

}

二、异常的处理方式

包括捕获异常和上抛异常

1、捕获异常

以捕获 int i=2/0 为例

try {
            int i = 2 / 0;

        } catch (Exception ex) {// 所有异常的父类Exception
            ex.printStackTrace();
            // 处理异常
            System.out.println("异常信息:" + ex.getMessage());
        }

         finally {
            System.out.println("释放资源,后续代码,一定要执行的代码");
        }
        System.out.println("继续运行");

输出结果为

在这里插入图片描述

ex.printStackTrace()表示向控制台打印详细异常信息

2、上抛异常 throws

String str =null;

str.length();(未实例化)为例

package test;

import com.hanqi.ThrowEX;

public class Test {
    public void test() throws Exception { //用throws
        String str = null;
        str.length();
    }

    public static void main(String[] args) {
        ThrowEX te = new ThrowEX();    //用throw
        try {
            te.test();
        } catch (Exception e) {// TODO 自动生成的 catch块
            e.printStackTrace();
            System.out.println("异常信息为" + e.getMessage());
        }

    }
}

在这里插入图片描述

e.printStackTrace()表示向控制台打印详细异常信息

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值