Нужна помощь в создании параметризованного запроса с помощью Pentaho CDE - PullRequest
2 голосов
/ 18 октября 2011

Я разрабатываю одну приборную панель с использованием Pentaho CDE. Я создал один запрос для извлечения названий организаций из базы данных. Следующий запрос прекрасно работает для меня:

select top 5 
employer_name,count(emp_id) as emp_count
from employment_details 
where employer_name=${employer}
group by employer_name 
order by emp_count desc 

Я хочу изменить предложение where, чтобы вместо использования = я хотел использовать предложение like. Поэтому я изменил запрос следующим образом:

select top 5 
employer_name,count(emp_id) as emp_count
from employment_details 
where employer_name like ${employer}
group by employer_name 
order by emp_count desc

но это не дает мне надлежащих результатов. Например, если значение ${employer} равно IBM, тогда запрос возвращает строки, имеющие имя Employer_name точно так же, как IBM.

Я попытался изменить условие where на where employer_name like '%${employer}%', но оно не работает.

РЕДАКТИРОВАТЬ 1

Согласно предложениям pdpi, я пытался использовать двойные кавычки вместо одинарных кавычек в районе $ {работодателя}, но теперь я получаю исключение Parent exception: Invalid parameter index 1.. Ниже приводится некоторая часть stacktrace:

pt.webdetails.cda.dataaccess.QueryException: Found an unhandled exception:
        at pt.webdetails.cda.dataaccess.SimpleDataAccess.queryDataSource(SimpleDataAccess.java:299)
        at pt.webdetails.cda.dataaccess.AbstractDataAccess.doQuery(AbstractDataAccess.java:312)
        at pt.webdetails.cda.CdaEngine.doQuery(CdaEngine.java:51)
        at pt.webdetails.cda.CdaContentGenerator.doQuery(CdaContentGenerator.java:299)
        at pt.webdetails.cda.CdaContentGenerator.createContent(CdaContentGenerator.java:139)
        at org.pentaho.platform.web.servlet.GenericServlet.doGet(GenericServlet.java:261)
        at org.pentaho.platform.web.servlet.GenericServlet.doPost(GenericServlet.java:80)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.j
    ava:290)
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
            at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
            at org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:861)
            at org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process(Http11AprProto
    col.java:579)
            at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1584)
            at java.lang.Thread.run(Thread.java:619)
    Caused by: pt.webdetails.cda.dataaccess.QueryException: ReportDataFactoryException : Failed at query
    : select top 5
    emp.employer_name,count(emp.rinx_id) as candidate_count
    from tbl_cand_employment_details emp
    where emp.employer_name like "%${employer}%"
    group by emp.employer_name
    order by candidate_count desc; Parent exception: Invalid parameter index 1.
            at pt.webdetails.cda.dataaccess.PREDataAccess.performRawQuery(PREDataAccess.java:116)
            at pt.webdetails.cda.dataaccess.SimpleDataAccess.queryDataSource(SimpleDataAccess.java:288)
            ... 68 more

Пожалуйста, помогите мне в формировании этого запроса.

РЕДАКТИРОВАТЬ 2

Моя проблема решена сейчас. Благодаря этому вопросу на форуме в Пентахо.

Я изменил условие where следующим образом, и теперь оно работает:

where employer_name like '%' + ${employer} + '%'

Ответы [ 2 ]

1 голос
/ 18 октября 2011

Как говорит PDPI, вы должны использовать "% $ {работодатель}%", то есть двойные кавычки, а не одинарные. Тогда это должно работать.

1 голос
/ 18 октября 2011

Я решил похожую проблему, используя CDF и Action Sequence Files. Мне кажется, что вы пытаетесь параметризовать запрос в Javascript. В этом случае компонентный объект имеет поле parameters , которое принимает массив параметров. Используется как так;

parameters : [ [ "REGION", "region" ], [ "DISTRICT", "district" ],
                [ "SUB_DISTRICT", "subDistrict" ] ]

Также есть поле слушателя, которое используется для обновления вашего компонента при изменении параметра. См. Ссылку на CDF внутри вашего решения Pentaho для получения более подробной информации.

...