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]})'