jstl中判断查询结果是否为空
表1:javax.servlet.jsp.jstl.sql.Result 接口定义的属性 属性 说明 rows 一排SortedMap 对象,每个对象对映列名和结果集中的单行 rowsByIndex 一排数组,每个对应于结果集中的单行 columnNames 一排对结果集中的列命名的字符串,采用与rowsByIndex属性相同的顺序 rowCount 查询结果中总行数 limitedByMaxRows 如果查询受限于maxRows 属性值为真 |
如<c:if test="${result.rows[0]==0}" 就可以判断了。
do something
</c:if>
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指令,指定引用的标签库,如下:
一般用途的标签有<c:out>、<c:set>、<c:remove>、<c:cath>
1.<c:out>
用于计算一个表达式并将结果输出。类似于JSP 中<%=%>表达式,或者是EL中$ ${el-expression}。
2.<c:set>
用于设置范围变量的值或者javabean对象的属性。
看个实际例子:
这样就相当于设置了session。
3.<c:remove>
相对<c:set>其作用是移除范围变量。比如
4.<c:catch>
用于捕获在其中嵌套的操作所抛出的异常对象,并将异常信息保存到变量中。
我们将有可能抛出异常的代码放置到开始标签:<c:catch>和结束标签:</c:catch>之间。如果其中代码出现异常,异常对象将被捕获,保存在var声明的变量中,该变量总是有page范围。如果没有发生异常,而var所标识的范围变量将被移除。
如果没有指定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()
条件标签包括<c:if><c:choose><c:when><c:otherwise>
1.<c:if>
用于实现java中的if语句功能。
This is your first visit .
</c:if>
若为true,会打印中间部分。也可以声明var,方便下一步判断。
<c:out value=”${result}” />
2.<c:choose>
<c:choose>和<c:when>、<c:otherwise>一起实现互斥条件执行,类似于java中的if else.
<c:choose>一般作为<c:when>、<c:otherwise>的父标签。
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>
迭代标签 迭代标签有<c:forEach>和</c:forEach>
//遍历记录集
<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}
</c:forEach>
如果再加个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 首尾的空格,并将其返回
主要是替换
<sql:setDataSource var="dataSrc"
url="jdbc:jtds:sqlserver://localhost/LOG_DB" driver="net.sourceforge.jtds.jdbc.Driver"
user="sa" password="admin"/>
<%-- Set number of rows to process --%>
<c:set var="noOfRows" value="100" />
<c:set var="msg" value="select top 100 * from L_ips_tb where id> (select max (id) from
(select top ard id from L_ips_tb order by id) as T
) order by id"/>
<c:set var="test" value="${fn:replace(msg,'ard',100)}" />
<c:out value="${test}" />
<sql:query var="empList"
sql="${test}" dataSource="${dataSrc}"
/>
<c:out value="${fn:length(empList.rows)}"/>
使用反射
<c:setvar="arrayvalue"value="ID,SrcIP"/>
<c:setvar="delim"value=","/>
<c:setvar="array"value="${fn:split(arrayvalue,delim)}"/>
<c:setvar="count"value="${fn:length(array)}"/>
array是一个String数组,loghistory是一个Map
<c:forEachvar="loghistory"items="${loghistory}"varStatus="statusindex">
<c:forEachbegin="0"end="${count-1}""varStatus="index">
<c:outvalue="${loghistory[array[index.index]]}"/>
</c:forEach>
<c:choose>
使用二维数组
<c:forEach items="${applicationScope[param.answersMapName]}"
var="a">
${a.key}) ${a.value}:
${applicationScope[param.votesMapName][a.key]}<br>
</c:forEach〉
相关推荐
### JSTL标准标签库详解及使用指南 #### 一、引言 JSTL(JavaServer Pages Standard Tag Library,JavaServer 页面标准标签库)是一种用于简化JavaServer Pages (JSP) 页面开发的标准标签库。它由Apache Jakarta...
### JSTL标签库概述与应用 JSTL(JavaServer Pages Standard Tag Library)标签库是一种简化JSP页面开发的标准工具集,它提供了一系列预定义的标签,用于控制流程、国际化的文本处理、URL操作、数据库访问等。通过...
### JSTL 标签库概述与应用 JSTL(JavaServer Pages Standard Tag Library,JSP标准标签库)是一种广泛应用于JSP页面的技术,它通过一组预定义的标签简化了网页开发工作,使得开发者无需编写复杂的Java代码即可实现...
在使用JSTL标签之前,需要在JSP页面顶部声明使用的标签库: ```jsp <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> ``` 其中: - `uri`:标签库的URI。 - `prefix`:前缀,用于引用该标签库...
### JSTL 标签库概述与用法详解 #### 一、JSTL简介 JSP Standard Tag Library (JSTL) 是一组定制的标签,用于实现许多常见的Web站点功能,以标准化的方式进行封装。它极大地简化了JSP页面的设计,通过提供一系列...
### JSTL C标准标签库概述 JSTL(JavaServer Pages Standard Tag Library),即JavaServer Pages标准标签库,是一个不断完善的开源项目,由Apache的Jakarta小组维护。该标签库旨在提供一套标准且功能丰富的标签集合...
### EL表达式和JSTL标签详解 #### 一、EL表达式 ##### 1. EL简介 **1.1 语法结构** EL (Expression Language) 表达式的语法非常简单,采用 `${expression}` 的形式来表示。这种语法可以在任何 HTML 和 JSP 标签...
- 提升性能:JSTL标签在服务器端被编译为Java代码,执行效率相对较高。 **8. JSTL与JSP自定义标签的区别** JSTL是预定义的一组标签,而JSP自定义标签是开发人员根据需求自行创建的标签库。JSTL已经包含了大量常用...
JSTL标签库中,表达式语言(EL,Expression Language)扮演着重要的角色,它允许开发者在不使用任何Java脚本的情况下,访问并操作JSP页面上的对象。EL语法简洁,类似于`{}`中的表达式,可以直接引用请求、会话、应用...
JSTL由多个标签库组成,其中最常用的包括核心标签库(Core)、SQL标签库(SQL)、函数标签库(FUNC)以及格式化标签库(FMT)等。格式化标签库(FMT)主要用于处理文本的国际化和格式化问题,例如日期、时间、数字等的格式化...
JSTL sql标签库** sql库用于执行数据库操作,包括连接数据库、执行SQL语句、处理结果集等,如: - `<sql:query>`:执行SQL查询 - `<sql:update>`:执行SQL更新 - `<sql:params>`:传递参数到SQL语句 **5. JSTL xml...
6. **JSTL SQL标签库** SQL库提供了与数据库交互的功能,如`<sql:update>`执行SQL更新语句,`<sql:query>`执行查询并返回结果集。 7. **CHM格式介绍** CHM(Microsoft Compiled HTML Help)是一种Windows平台上的...
- **简介**: SQL标签库用于在JSP页面中执行简单的SQL操作,如查询数据库等。 - **标签示例**: - `<sql:query>`: 执行SQL查询语句并返回结果集。 - `<sql:update>`: 更新数据库表中的数据。 - **示例**: `<sql:...
4. **SQL标签库**:用于执行数据库操作,URI为`http://java.sun.com/jstl/sql`,推荐前缀为`s`。 JSTL的使用可以减少在JSP页面中直接使用Java脚本,提高页面的可读性和维护性。它通过提供一套标准的标签,使得...
- 提升性能:JSTL标签通常比Java脚本运行得更快,因为它们在服务器端被编译成Java代码。 - 代码分离:JSTL有助于实现表现层和逻辑层的分离,遵循MVC设计模式。 - 更好的维护性:通过使用JSTL,可以降低代码的复杂...