DatabaseFilter学习笔记

首先建立数据库控件canton.jcx

这里主要用到该控件的getAllBCanton

/**
* @jc:sql command-type="grid"
* rowset-name="B_CANTONRowSet"
* max-rows="1000"
* statement="SELECT CANTON_ID,PLACENAME,ZIP,PRE_PHONE,REMARK,DELETED,CANTON_LEVEL,UPPER_CANTON_ID FROM HAPPYTREE.HT_B_CANTON {sql: filter.getWhereClause ()} {sql: filter.getOrderByClause ()}"
*/
public RowSet getAllBCanton(DatabaseFilter filter)
throws SQLException;

可以看见上面方法的参数是DatabaseFilter类型,我们的主要任务就是传递一个参数到该方法中,方法返回RowSet类型的数据

构建一个jpf页面流

在该页面流中有一个jsp页面负责输入查询的条件select.jsp

代码如下:

新建 Web 应用程序页

Canton_id:

有一个负责显示查询结果的页面grid.jsp

代码为:

select页面表单的action为select,这样在页面流中的方法select如下:
/**
* @jpf:action
* @jpf:forward name="success" path="grid.jsp"
*/
protected Forward select(DatabaseForm form)
{
sortFilterService = SortFilterService.getInstance(getRequest());
//实例化一个SortFilterService
DatabaseFilter filter = new DatabaseFilter();
//创建一个DatabaseFilter对象filter
List list = new ArrayList();//用于存储查询条件FilterTerm
DatabaseFilter.FilterTerm query = new DatabaseFilter.FilterTerm();
query.sColumnName = "canton_id";//查询的列为caton_id,canton_id数据库中的一个字段
query.op = DatabaseFilter.opGreater;//比较条件是大于
//这里还有大于、小于、不等于、为空、不为空等条件,根据情况具体设定
//query.value = "000000";//比较的值
query.value = form.getCanton_id();
list.add(query);//比较条件加入
DatabaseFilter.FilterTerm[] term = new DatabaseFilter.FilterTerm[list.size()];
//设定FilterTerm把比较的内容,即where后面的条件
for(int i=0;i term[i] = (DatabaseFilter.FilterTerm)list.get(i);//把条件加入terms
}
DatabaseFilter.SortTerm[] sterm = new DatabaseFilter.SortTerm[1];//设定排序字段
sterm[0] = new DatabaseFilter.SortTerm();
sterm[0].sColumnName = "placename";//排序字段
sterm[0].op = DatabaseFilter.opDesc;//降序排列
filter = new DatabaseFilter(term,sterm);//构造databasefilter
try{
allRows = myControl.getAllBCanton(filter);//执行查询语句,并付给allRows
}catch(Exception e){
e.printStackTrace();
}
return new Forward("success",new DatabaseForm());
}

至此就ok了,这里只是一个简单的例子,多条件查询只要往list内加入条件就行了.

时间: 2024-10-06 03:23:03

DatabaseFilter学习笔记的相关文章

JetSpeed学习笔记(一)

笔记 JetSpeed学习笔记(一) fuweilin 2005-4-7 前言 参加了公司的portal的兴趣小组,今天对portal进行学习.首先上网看了看一些portal的资料,对portal.portlet.portlet container以及JSR168等概念有个基本的了解.决定进一步实战的方式感受portal,于是学习JetSpeed.     1.  JetSpeed介绍JetSpeed是Apache组织开发的一个采用Java和XML的开放源代码的企业信息门户的实现.门户可以让终端

PHP输入输出流学习笔记

  这篇文章主要介绍了PHP输入输出流学习笔记,PHP输入和输出流是通过php://来访问的,它允许访问 PHP 的输入输出流.标准输入输出和错误描述符,内存中.磁盘备份的临时文件流以及可以操作其他读取写入文件资源的过滤器,需要的朋友可以参考下 PHP输入和输出流是通过php://来访问的,它允许访问 PHP 的输入输出流.标准输入输出和错误描述符, 内存中.磁盘备份的临时文件流以及可以操作其他读取写入文件资源的过滤器. php://stdin, php://stdout 和 php://std

PHP学习笔记 (1) 环境配置与代码调试

一配置PHP环境 1.了解什么是PHP PHP("PHP: Hypertext Preprocessor",超文本预处理器的字母缩写) PHP,是英文超级文本预处理语言Hypertext Preprocessor的缩写.PHP 是一种 HTML 内嵌式的语言,是一种在服务器端执行的嵌入HTML文档的脚本语言,语言的风格有类似于C语言,被广泛的运用 2.PHP的背景和优势 PHP的发展背景 1).1994年由Rasmus Lerdorf创建,开始是一个简单的Perl语言编写的程序,用统计

Node.js 学习笔记之简介、安装及配置

 本文是Node.js学习笔记系列文章的第一篇,主要给大家讲解的是在Windows和Linux上安装Node.js的方法.软件安装版本以0.12.0为例.希望大家能够喜欢.     简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台. Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好. 谁适合阅

node.js学习笔记(9) 和谐模式

众所周知,ECMAScript 是一种开放的.国际上广为接受的脚本语言规范. 它本身并不是一种脚本语言.正如在 Web 应用程序中执行有用操作的 bean 集合(例如,Netscape 的 AWT)是 Sun 的 JavaBean 规范的一种实现一样,JavaScript 是 ECMAScript 规范的一种实现. 2015年6月17日,ECMA国际发布了EcmaScript2015,即EcmaScript6(以下简称ES6)草案的正式版.ES6是继ES5之后的一次主要改进,语言规范由ES5.1

php5学习笔记(转)

php5|笔记 作者: whhwq在phpv.net看到的感觉不错/*+-------------------------------------------------------------------------------+| = 本文为Haohappy读<<Core PHP Programming>> | = 中Classes and Objects一章的笔记 | = 翻译为主+个人心得 | = 为避免可能发生的不必要的麻烦请勿转载,谢谢 | = 欢迎批评指正,希望和所有

动态网页学习:JSP学习笔记全记录

js|笔记|动态|网页 JSP学习笔记(一)-----概述 JSP学习笔记(二)-----使用Tomcat运行JSP文件 JSP学习笔记(三)-----使用JSP处理用户注册和登陆 JSP学习笔记(四)-----JSP动作的使用 JSP学习笔记(五)-----JSP中使用JavaBean JSP学习笔记(六)-----在多个JSP页面之间传递参数 JSP学习笔记(七)-----猜数字游戏 JSP学习笔记(八)-----include的运用 JSP学习笔记(九)-----JSP标签库

java对象序列化学习笔记

java对象|笔记 目前网络上关于对象序列化的文章不少,但是我发现详细叙述用法和原理的文章太少.本人把自己经过经验总结和实际运用中的体会写成的学习笔记贡献给大家.希望能为整个java社区的繁荣做一点事情.    序列化的过程就是对象写入字节流和从字节流中读取对象.将对象状态转换成字节流之后,可以用java.io包中的各种字节流类将其保存到文件中,管道到另一线程中或通过网络连接将对象数据发送到另一主机.对象序列化功能非常简单.强大,在RMI.Socket.JMS.EJB都有应用.对象序列化问题在网

Java的“对象思想”学习笔记[二]

笔记|对象 在这篇文章里我将介绍一些Java对于对象的基本处理模式的问题. 首先看一个有关对象相等性(Object equivalence)的例子: 先看下面的代码: public class EqualTest1{ public static void main(String[] args){ Integer n1 = new Integer(20); Integer n2 = new Integer(20); System.out.println(n1 = = n2); System.out