Por ejemplo, considere la consulta de ejemplo /Public Queries/Reports/State Query. Esta consulta incluye un filtro dinámico que permite especificar uno o más valores de estado. Cada cliente de ClearQuest proporciona una interfaz para solicitar los valores de filtro y operador. En el modelo de informes de obtención de datos, el controlador de informes de ClearQuest también necesita un mecanismo para recuperar esta información.
Debido a que los filtros dinámicos le solicitan dos elementos de información, el controlador de informes de ClearQuest trata cada filtro como dos parámetros distintos. Durante el tiempo de ejecución, debe especificar el operador de filtro y los valores. Los ejemplos proporcionados con la distribución incluyen una biblioteca de BIRT que contiene un parámetro de operador de ejemplo que puede utilizar para visualizar operadores. Puede utilizar el parámetro de ejemplo directamente o copiar los controles para sus propios informes.
Los operadores IS_BETWEEN y IS_NOT_BETWEEN presentan un reto cuando se utiliza el modelo de obtención de datos porque es necesario un total de tres argumentos (operador, operando bajo y operando alto). El controlador de informes de ClearQuest no da soporte directamente al operador IS_BETWEEN y al operador IS_NOT_BETWEEN. Sin embargo, puede conseguir el mismo comportamiento de estos operadores mediante la creación de una consulta de ClearQuest que utilice dos filtros agrupados con un AND en el constructor de consultas. Durante el tiempo de ejecución, el controlador de informes de ClearQuest crea cuatro parámetros para los dos filtros, que simulan el operador IS_BETWEEN y el operador IS_NOT_BETWEEN.
En los ejemplos siguientes, las series de texto en negrita son los valores que se proporcionan durante el tiempo de ejecución.
Considere la siguiente expresión de filtro:
DateField
IS_BETWEEN
12-12-2005
AND
12-12-2007
Se pueden conseguir los mismos resultados utilizando dos filtros, tal como se muestra en el ejemplo siguiente:
DateField
IS_GREATER_THAN_OR_EQUAL
12-12-2005
AND
IS_LESS_THAN_OR_EQUAL
12-12-2007