jsp web的一些问题

1.JSP中JavaBean的四种作用范围

http://mgc.name/article.asp?id=82

 

2.jsp中request.getparameter()与session.getAttribute()有什么区别

两者都是取得对象的值

request.getParameter(),是用来取页面的值,仅取一次,取过之后,就取不到了。一般注册,登陆类似的模块用这个。

session.getAttribute()可以获取页面上的值,通常是获取放进session中的对象值。如果页面不作声明,默认是对象值是放进request中的。也可以获取session自身里面的对象值。有些对象是放进session里面的通过这个方法,可以得到。

3.查看JSP内置对象的常用方法

http://download.oracle.com/docs/cd/E17802_01/products/products/servlet/2.5/docs/servlet-2_5-mr2/index.html

4.jsp中的EL表达式

JSP用于在网页上显示动态内容,通常需要在JSP页面中嵌入Java脚本以完成复杂功能。但大量的Java脚本使得JSP页面难以维护。一种类似JavaScript语言—JSP表达式语言可用于在网页上生成动态内容,并代替JSP脚本元素(表达式、Script、声明),EL表达式可用于所有的HTML和JSP标签中。
EL表达式语法: ${ EL expression} 其中:
$表示EL表达式的开始。 EL expression指定表达式。
一、JSP EL表达式可用于如下几种方式。
1 静态文本:包含EL表达式,其值在运行时计算出来。
如: ${8+5}
2 标准标签和自定义标签属性:帮助显示网页上的动态内容。
JSP提供一些标准标签,<jsp:useBean>、<jsp:include>等。自定义标签是由用户使用taglib指令编写的。
EL表达式可以作为一个值传递给上述标签的属性。表达式在运行时计算,结果值将作为属性值进行传递。
如: <% pageContext.setAttribute("color","#ffccff");%>

<body bgcolor="${pageScope.color}">
7+8=${7+8}

</body>
3 JavaBean与EL表达式:使用EL表达式可以简洁地读出JavaBean的属性值。
传统的JSP通常使用如下方法访问JavaBean:
<jsp:getProperty name=”myBean” property=”name”/>
<%=myBean.getName()%>
EL表达式则简化为:
${myBean.name}
二、启用/禁用EL表达式
<%@ page isELIgnored=”true|false” %> 为true时,支持EL表达式计算。
false时,不支持EL表达式计算。
三、变量
JSP表达式${product}的计算结果与调用pageContext.findAttribute(“product”)一样,EL表达式中的变量可以引用存储在标准范围(如:page request session application)中的属性。
点运算符(.)和”[]”用于获取变量的值。
如:a.identifier-b与expr-a[identifier-b]等价。
四、隐式对象
JSP隐式对象是一组标准的类。在JSP EL定义了如下隐式对象:
1 pageContext:提供对页面属性的访问。通过pageContext对象可以访问和使用下列对象。
2 request:表示接受的客户端的JSP页面请求。请求的信息可以使用request对象来访问。如:${pageContext.request.contextPath}返回请求的上下文路径。
3 param:返回将请求参数名映射至单个字符串值的值。如:${param[“name”]}
4 paramValues:返回映射至客户端的请求参数的一组值。
5 pageScope:返回页面范围的变量名,这些名称已映射至相应的值。
6 requestScope:提供对请求对象的属性的访问权限。

7 sessionScope:返回会话范围内的变量名。
8 applicationScope: 返顺应用程序范围内抽变量名。
五、文字常量
JSP表达式语言定义了下列文字常量:
1 布尔型:true或false。
2 整型:与Java中的整型相同。
3 浮点型:与Java中的浮点型相同。
4 字符串型:用单引号或双引号引起。
5 null:表示没有值。0和空字符串表示的不是null值。
六、运算符
点运算符(.)和”[]”用于获取变量的值。
!或not 布尔值取反
empty 检查空值
* 乘法
/或div 除法
%或mod 求余数或取模
+ 加 - 减 <或lt 小于 >或gt 大于 <=或le 小于等于 >=或ge 大于等于 ==或eq 等于 !=或ne 不等于 &&或and 逻辑与 ||或 or 逻辑或 num1?num2:result 条件运算符 

5.页面跳转与请求转发

http://quicker.javaeye.com/blog/571748

6.转发和重定向

http://www.javaeye.com/topic/372941

7.JSP中操作数据库的三个对象:Statement;PreparedStatement;CallableStatement

statement

 

 

1、创建 Statement 对象

  建立了到特定数据库的连接之后,就可用该连接发送 SQL 语句。Statement 对象用 Connection 的方法 createStatement 创建,如下列代码段中所示:

Connection con = DriverManager.getConnection(url, "sunny", "");
Statement stmt = con.createStatement();

  为了执行 Statement 对象,被发送到数据库的 SQL 语句将被作为参数提供给 Statement 的方法:

ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table2");

  2、使用 Statement 对象执行语句

  Statement 接口提供了三种执行 SQL 语句的方法:executeQuery、executeUpdate 和 execute。使用哪一个方法由 SQL 语句所产生的内容决定。

  方法 executeQuery 用于产生单个结果集的语句,例如 SELECT 语句。

  方法 executeUpdate 用于执行 INSERT、UPDATE 或 DELETE 语句以及 SQL DDL(数据定义语言)语句,例如 CREATE TABLE 和 DROP TABLE。INSERT、UPDATE 或 DELETE 语句的效果是修改表中零行或多行中的一列或多列。executeUpdate 的返回值是一个整数,指示受影响的行数(即更新计数)。对于 CREATE TABLE 或 DROP TABLE 等不操作行的语句,executeUpdate 的返回值总为零。

  方法 execute 用于执行返回多个结果集、多个更新计数或二者组合的语句。因为多数程序员不会需要该高级功能,所以本概述后面将在单独一节中对其进行介绍。

  执行语句的所有方法都将关闭所调用的 Statement 对象的当前打开结果集(如果存在)。这意味着在重新执行 Statement 对象之前,需要完成对当前 ResultSet 对象的处理。

  应注意,继承了 Statement 接口中所有方法的 PreparedStatement 接口都有自己的 executeQuery、executeUpdate 和 execute 方法。Statement 对象本身不包含 SQL 语句,因而必须给 Statement.execute 方法提供 SQL 语句作为参数。PreparedStatement 对象并不将 SQL 语句作为参数提供给这些方法,因为它们已经包含预编译 SQL 语句。CallableStatement 对象继承这些方法的 PreparedStatement 形式。对于这些方法的 PreparedStatement 或 CallableStatement 版本,使用查询参数将抛出 SQLException。

  3、语句完成

  当连接处于自动提交模式时,其中所执行的语句在完成时将自动提交或还原。语句在已执行且所有结果返回时,即认为已完成。对于返回一个结果集的 executeQuery 方法,在检索完 ResultSet 对象的所有行时该语句完成。对于方法 executeUpdate,当它执行时语句即完成。但在少数调用方法 execute 的情况中,在检索所有结果集或它生成的更新计数之后语句才完成。
   概述
   Statement 对象用于将 SQL 语句发送到数据库中。实际上有三种 Statement 对象,它们都作为在给定连接上执行 SQL 语句的包容器: Statement、PreparedStatement(它从 Statement 继承而来)和 CallableStatement(它从 PreparedStatement 继承而来)。它们都专用于发送特定类型的 SQL 语句: Statement 对象用于执行不带参数的简单 SQL 语句;PreparedStatement 对象用于执行带或不带 IN 参数的预编译 SQL 语句;CallableStatement 对象用于执行对数据库已存储过程的调用。
  Statement 接口提供了执行语句和获取结果的基本方法。PreparedStatement 接口添加了处理 IN 参数的方法;而 CallableStatement 添加了处理 OUT 参数的方法。
有些 DBMS 将已存储过程中的每条语句视为独立的语句;而另外一些则将整个过程视为一个复合语句。在启用自动提交时,这种差别就变得非常重要,因为它影响什么时候调用 commit 方法。在前一种情况中,每条语句单独提交;在后一种情况中,所有语句同时提交。
  4、关闭 Statement 对象
  Statement 对象将由 Java 垃圾收集程序自动关闭。而作为一种好的编程风格,应在不需要 Statement 对象时显式地关闭它们。这将立即释放 DBMS 资源,有助于避免潜在的内存问题。

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值