1、数据准备时,最好放在request里面,而不是session里面,因为session生命周期较长,而且是处于服务器端,非常耗内存,相反,request周期较短。
2、getAttribute和getParameter的区别:
(1)取值不同。getAttribute取到的是对象(object),而getParameter取到的是String。
(2)数据传递路径不同。request.getParameter()方法传递的数据,会从Web客户端传到Web服务器端,代表HTTP请求数据;request.setAttribute()和getAttribute()方法传递的数据只会存在于Web容器内部,在具有转发关系的Web组件之间共享。即request.getAttribute()方法返回request范围内存在的对象,而request.getParameter()方法是获取http提交过来的数据。
3、类似于购物商城里面的订单这样的逻辑,为避免数据的冗余,应该使用两张表,一张订单表、一张订单详情表。
4、关于超链接和按钮两种不同的跳转或者提交的方式:
超链接:<a href="#">提交</a>
按钮:<input type="button" value="提交" οnclick="methodName()"/>,然后在script标签里面定义方法function methodName(){window.location.href="#";}
5、读取数据库的某条记录的某个值,为保证安全性和可靠性,应设置事务的安全级别(可串行化级别)。比如,在购物商城里面,对订单的两表进行操作,第二张表需要得到第一张表刚插入的记录id。方法:conn.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);同时注意设置事务手动提交:conn.setAutoCommit(false);待整套操作完成后,在提交:conn.commit(),当然还要设置事务异常回滚。
6、session和application的区别:
session是会话变量,是基于单个用户的,只对单个用户有效,相当于个人邮箱。
application是全局变量,是基于整个web应用的,对所有用户有效,相当于公告栏。
两者的生命周期:
session:一般情况下,不管向服务器发送了多少次请求,只有当开始向session中存储会话状态数据时,即服务器端调用HttpServletRequest.getSession(true)这样的语句时,session才会被创建。一个常见的误解是session在有客户端访问时就被创建。session在下列情况下被删除:
a.程序调用HttpSession.invalidate();
b.距离上一次收到客户端发送的session id时间间隔超过了session的超时设置(默认是20分钟);
c.服务器进程被停止(非持久session)。
“只要关闭浏览器,由该浏览器所生成的session就会随之销毁。”这句话理解是错误的!
application:开始于向服务器发送的第一次请求,然后直到服务器关闭。
7、数据库使用完后要关闭的原因:
a:数据库的连接数是有限制的,如果一味取得连接而又不关闭,一旦连接数过多,系统就很容易down掉;(主要)
b:数据库连接占用内存(很小),一定程度上降低了数据库的访问效率。(次要)