首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 开源软件 >

wabacus学习记要01-查询条件(20120810)

2012-09-27 
wabacus学习记录01--查询条件(20120810)学习使用wabacus一段时间了,在这里把遇到的问题做一些整理1.查询条

wabacus学习记录01--查询条件(20120810)
学习使用wabacus一段时间了,在这里把遇到的问题做一些整理

1.查询条件

a.开始结束日期--结束日期默认是当前时间,开始日期默认回推一周


首先在拦截器里把开始结束时间放到request里

<interceptor>      <imports>       <import>com.wabacus.util</import>       <import>java.util</import>       <import>java.text</import>      </imports>      <preaction>       <![CDATA[        Date d=new Date();         String beginTime=rrequest.getStringAttribute("txtBeginTime","");//txtBeginTime为此<condition/>的name属性         if(beginTime.equals(""))         {//没有条件值           rrequest.setAttribute("txtBeginTime",DateFormat.getDateInstance().format(new Date(d.getTime() - 7 * 24 * 60 * 60 * 1000)));//将条件值设置进去。         }                String endTime=rrequest.getStringAttribute("txtEndTime","");//txtcheckDate为此<condition/>的name属性         if(endTime.equals(""))         {//没有条件值           rrequest.setAttribute("txtEndTime",DateFormat.getDateInstance().format(d));//将条件值设置进去。         }        //System.out.println("txtEndTime is :"+rrequest.getAttribute("txtBeginTime")+"===="+rrequest.getAttribute("txtEndTime"));           ]]>      </preaction>     </interceptor>


sql片段写成如下

column_date between cast('#txtBeginTime#' as datetime) and cast('#txtEndTime#' as datetime)


condition 配置如下
<condition name="txtBeginTime" label="开始日期"> <inputbox type="datepicker" jsvalidate="isDate({0}格式不对,必须为yyyy-MM-dd格式)"/></condition><condition name="txtEndTime" label="结束日期"> <inputbox type="datepicker" jsvalidate="isDate({0}格式不对,必须为yyyy-MM-dd格式)"/></condition>



b.查询条件来自session
例如拦截器里把某个参数放到session了,
<interceptor>    <preaction>        rrequest.getRequest().getSession().setAttribute("txtage","30");//在session中存入txtage的值为30,以便后面的查询条件能从中取到数据。     </preaction></interceptor>

condition中可以通过以下配置用session的值查询
<condition name="txtage" label="年龄" hidden="true" source="session">     <value>      <![CDATA[(age > #data#)]]>     </value></condition>


c.查询条件来自url,可直接使用
例如url有个参数是txt_CustCode,那么condition可以配置如下
<condition name="txt_CustCode" hidden="true" label="顾客编号">      <value>      <![CDATA[(CustCode = '#data#' )]]>      </value></condition>


d.select语句的条件不仅仅是在where之后
有两种方法
方法一:直接在SQL语句中通过#name#指定查询条件,其中name为<condition/>的name属性配置值,这样可以非常灵活地指定查询条件,不需要通过{#condition#} 占位符,具体可以参看DEMO的“数据展示篇”---“查询条件”---“在SQL语句中指定条件”的演示,以及开发指南关于这部分的介绍
方法二:使用存储过程查询报表数据。

热点排行