Mule / dataweave - невозможно получить запись / элемент, дата которых больше или равна другой дате - PullRequest
0 голосов
/ 25 января 2019

Я пытаюсь отфильтровать свою полезную нагрузку, применив фильтр к диапазону дат. К сожалению, я не думаю, что это работает, поскольку возврат данных недействителен. Ребята, можете ли вы помочь мне выяснить причину этой ошибки? К твоему сведению, я уже ввожу данные даты как localdatetime соответственно.

Variable

sessionVars.DateFrom = 2017-05-01T00: 00: 00

sessionVars.DateTo = 2017-09-01T23: 59: 59

Токовый вход

 <GetListOfCategoriesDetailResponse xmlns="" xmlns:s="">
    <GetListOfCategoriesDetailResult xmlns:a="" xmlns:i="">
        <a:CategoryDetail>
            <a:CategoryCode>ABC456</a:CategoryCode>
            <a:Arrive>2017-12-14T15:00:00</a:Arrive>
            <a:Depart>2018-01-10T15:00:00</a:Depart>
        </a:CategoryDetail>
        <a:CategoryDetail>
            <a:CategoryCode>ABC123</a:CategoryCode>
             <a:Arrive>2017-08-14T15:00:00</a:Arrive>
            <a:Depart>2017-08-20T15:00:00</a:Depart>
        </a:CategoryDetail>
        <a:CategoryDetail>
            <a:CategoryCode>BCD344</a:CategoryCode>
             <a:Arrive>2017-05-14T15:00:00</a:Arrive>
            <a:Depart>2017-06-01T15:00:00</a:Depart>
        </a:CategoryDetail>
    </GetListOfCategoriesDetailResult>
</GetListOfCategoriesDetailResponse>

Ожидаемый результат

<ns0:FoodProducts>
     <ns0:FoodProduct>
         <ns0:FruitTypes>
             <ns0:FruitType FruitTypeCode="ABC123">
          </ns0:FruitType>
             <ns0:FruitType FruitTypeCode="BCD344" >
             </ns0:FruitType>
     </ns0:FoodProduct>
 </ns0:FoodProducts>

Мой до сих пор dataweave код

%output application/xml
 %namespace ns0 
 %namespace ns01 
 %namespace ns1 
 ---
 {
     ns0#FoodProductRS: {
         ns0#FoodProducts: {
             ns0#FoodProduct: {
                 ns0#FruitTypes: {         
  (payload.ns01#GetListOfCategoriesDetailResponse.ns01#GetListOfCategoriesDetailResult.*ns1#CategoryDetail filter (sessionVars.DateTo as :localdatetime {format:"yyyy-MM-dd'T'HH:mm:ss"}) >= ($.Arrive as :localdatetime {format:"yyyy-MM-dd'T'HH:mm:ss"})
                and (sessionVars.DateFrom as :localdatetime {format:"yyyy-MM-dd'T'HH:mm:ss"}) <= ($.Depart as :localdatetime {format:"yyyy-MM-dd'T'HH:mm:ss"})
     map ((categoryDetail , indexOfCategoryDetail) -> {
                         ns0#FruitType @(FruitTypeCode: categoryDetail.ns1#CategoryCode)
                     }))
                 }
             }
         }
     }
 } 

1 Ответ

0 голосов
/ 25 января 2019

Я еще раз подтвердил, что это сравнение кода действительно работает, и я могу получить диапазон записей на основе сравнения localdatetime.

...