jstl中判断查询结果是否为空
表1:javax.servlet.jsp.jstl.sql.Result 接口定义的属性 属性 说明 rows 一排SortedMap 对象,每个对象对映列名和结果集中的单行 rowsByIndex 一排数组,每个对应于结果集中的单行 columnNames 一排对结果集中的列命名的字符串,采用与rowsByIndex属性相同的顺序 rowCount 查询结果中总行数 limitedByMaxRows 如果查询受限于maxRows 属性值为真 |
如 do something
JSP 标准标记库(Standard Tag Library,JSTL)是一组以标准化格式实现许多通用的Web站点功能的定制标记。 JSTL的目标是为了简化JSP 页面的设计。
一.配置JSTL
包括两个JAR文件,jstl.jar 和standard.jar。是什么没有必要管
原文引入:
< %@ taglib prefix ="sql" uri ="http://java.sun.com/jsp/jstl/sql" % >
< %@ taglib prefix ="fmt" uri ="http://java.sun.com/jsp/jstl/fmt" % >
二.Core标签库
Core标签库主要包括了一般用途的标签、条件标签、迭代标签和URL相关的标签。在JSP页面使用Core标签,要使用taglig指令,指定引用的标签库,如下:
一般用途的标签有
1.
用于计算一个表达式并将结果输出。类似于JSP 中<%=%>表达式,或者是EL中$ ${el-expression}。
2.
用于设置范围变量的值或者javabean对象的属性。
看个实际例子:
这样就相当于设置了session。
3.
相对
4.
用于捕获在其中嵌套的操作所抛出的异常对象,并将异常信息保存到变量中。
我们将有可能抛出异常的代码放置到开始标签:
如果没有指定var属性,异常只是简单的被捕获,异常信息并不会被保存。
Eg:
<%
int i = 5;
int j = 0;
int k =i/j;
% >
c:catch >
< c:out value =”${exception}” />< br >
< c:out value =”${exception.massage}”/>
后一句相当于:exception.getMessage()
条件标签包括
1.
This is your first visit .
>
若为true,会打印中间部分。也可以声明var,方便下一步判断。
2.
eg:
< c:when test ="${row.v_money<10000}" >
初学下海
c:when >
< c:when test ="${row.v_money>=10000&&row.v_money<20000}" >
身手小试
c:when >
< c:otherwise >
商业能手
c:otherwise >
c:choose >
迭代标签 迭代标签有
//遍历记录集
< tr class ="<%=tdClass[(rank+1)%2]%>" >
< td align ="center" >< span >< %=rank % > span > td >
< td align ="center" >< span >< c:out value ="${row.player_name}" /> span > td >
< td align ="center" >< span > ¥ < c:out value ="${row.money}" /> span > td >
tr >
< %rank ++;% >
c:forEach >
也可以设定固定次数。
${i}
>
如果再加个step=“2”那么每次增长为2。
三.sql标签
//设置数据源:
//将数据库某查询的结果声明为一个变量
select player_name,money from tb_player order by money DESC LIMIT 10
sql:query >
然后可以:
advCosts[${s.index}]=${row.adv_cost};
c:forEach >
数据更新标签:
call proc_set_role_salespro(?,?,?,?,?);
< sql:param value ="30" />
< sql:param value ="39" />
< sql:param value ="<%=spID%>" />
< sql:param value ="<%=productID%>" />
< sql:param value ="1" />
sql:update >
四.格式化标签
将输出12.300.应用样式”.000”,将使格式化后的小数部分有3位。不足3位将以0补齐
格式化的结果是:2007-5-27.
格式化的结果是:9:25:11
格式化的结果是: 2007-5-27 9:25:11
fn函数
JSTL1.1标签库还包含了许多其它经常使用的函数:
fn:contains(string, substring)
如果参数string中包含参数substring,返回true
fn:containsIgnoreCase(string, substring)
如果参数string中包含参数substring(忽略大小写),返回true
fn:endsWith(string, suffix)
如果参数 string 以参数suffix结尾,返回true
fn:escapeXml(string)
将有特殊意义的XML (和HTML)转换为对应的XML character entity code,并返回
fn:indexOf(string, substring)
返回参数substring在参数string中第一次出现的位置
fn:join(array, separator)
将一个给定的数组array用给定的间隔符separator串在一起,组成一个新的字符串并返回。
fn:length(item)
返回参数item中包含元素的数量。参数Item类型是数组、collection或者String。如果是String类型,返回值是String中的字符数。
fn:replace(string, before, after)
返回一个String对象。用参数after字符串替换参数string中所有出现参数before字符串的地方,并返回替换后的结果
fn:split(string, separator)
返回一个数组,以参数separator 为分割符分割参数string,分割后的每一部分就是数组的一个元素
fn:startsWith(string, prefix)
如果参数string以参数prefix开头,返回true
fn:substring(string, begin, end)
返回参数string部分字符串, 从参数begin开始到参数end位置,包括end位置的字符
fn:substringAfter(string, substring)
返回参数substring在参数string中后面的那一部分字符串
fn:substringBefore(string, substring)
返回参数substring在参数string中前面的那一部分字符串
fn:toLowerCase(string)
将参数string所有的字符变为小写,并将其返回
fn:toUpperCase(string)
将参数string所有的字符变为大写,并将其返回
fn:trim(string)
去除参数string 首尾的空格,并将其返回
主要是替换
user="sa" password="admin"/>
<%-- Set number of rows to process --%>
/>
使用反射
array是一个String数组,loghistory是一个Map
使用二维数组
${a.key}) ${a.value}:
${applicationScope[param.votesMapName][a.key]}