学习使用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语句中指定条件”的演示,以及开发指南关于这部分的介绍
方法二:使用存储过程查询报表数据。
限制日期只能选周的某几个
在inputbox的styleproperty里加入 onFocus='WdatePicker({disabledDays:[0,6]})'