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 ="c"  uri ="http://java.sun.com/jsp/jstl/core"  % >

< %@ 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指令,指定引用的标签库,如下:

< %@ taglib  uri =”http://java.sun.com/jsp/jstl/core”  prefix =”c”  % >

 

一般用途的标签有

1.

用于计算一个表达式并将结果输出。类似于JSP <%=%>表达式,或者是EL$ ${el-expression}

2.

用于设置范围变量的值或者javabean对象的属性。

看个实际例子:

< c:set  var =”username”  value =”lisi”  scope =”session”/>

这样就相当于设置了session

 3.

相对其作用是移除范围变量。比如

< c:remove  var =”nusername”  scope =”session”/>

4.

 用于捕获在其中嵌套的操作所抛出的异常对象,并将异常信息保存到变量中。

我们将有可能抛出异常的代码放置到开始标签:和结束标签:之间。如果其中代码出现异常,异常对象将被捕获,保存在var声明的变量中,该变量总是有page范围。如果没有发生异常,而var所标识的范围变量将被移除。

如果没有指定var属性,异常只是简单的被捕获,异常信息并不会被保存。

Eg

 

< c:catch  var =”exception”>
<%
       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.
用于实现java中的if语句功能。

< c:if  test =”${user.visitCount==1}”>

       
This is your first visit .

>

若为true,会打印中间部分。也可以声明var,方便下一步判断。

 

< c:if  test =”${param.name==’admin’}”  value =”result”/>
=”${result}”  />

2.
一起实现互斥条件执行,类似于java中的if else.
一般作为的父标签。

eg

< c:choose >
       
< 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  items ="${finalResult.rows}"  var ="row" >         
< 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 >  

 

也可以设定固定次数。

 

< c:forEach  var  =”i”  begin =”100  “ end = “110”>

       
${i}

>

 

如果再加个step=2”那么每次增长为2

 

三.sql标签

 

//设置数据源:

< sql:setDataSource  dataSource ="proxool.breadTycoon"   />

//将数据库某查询的结果声明为一个变量

< sql:query  var ="finalResult"   >
    select player_name,money from tb_player order by money DESC LIMIT 10    
sql:query >

       然后可以:

< c:forEach  items ="${ finalResult.rows}"  var ="row"  varStatus ="s" >

        advCosts[${s.index}]=${row.adv_cost};

   
c:forEach >

      数据更新标签:

      < sql:update >    
                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 >

 

四.格式化标签

< fmt:  formatNumber value  =”12.3”  pattern =”.000”/>

将输出12.300.应用样式”.000”,将使格式化后的小数部分有3位。不足3位将以0补齐

    < fmt:formatDate  value =”<%=new  java.util.Date() % > ” type=”date” />

 格式化的结果是:2007-5-27.

< fmt:formatDate  value =”<%=new  java.util.Date() % > ” type=”time” />

格式化的结果是:9:25:11

< fmt:formatDate  value =”<%=new  java.util.Date() % > ” type=”both” />

 

格式化的结果是: 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 首尾的空格,并将其返回

 主要是替换
    url="jdbc:jtds:sqlserver://localhost/LOG_DB" driver="net.sourceforge.jtds.jdbc.Driver"
    user="sa" password="admin"/>
    <%-- Set number of rows to process --%>
   
   
 

 
          sql="${test}"       dataSource="${dataSrc}"
    />
  
使用反射




array是一个String数组,loghistory是一个Map






使用二维数组
          var="a">
          ${a.key}) ${a.value}:
          ${applicationScope[param.votesMapName][a.key]}