All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.yupana.schema.ReceiptRollups.scala Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2019 Rusexpertiza LLC
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.yupana.schema

import org.yupana.api.query._
import org.yupana.api.query.syntax.All.dimension
import org.yupana.api.schema.TsdbRollup

object ReceiptRollups {
  import org.yupana.schema.ReceiptTableMetrics.ReceiptRollupFields._

  val receiptDayRollup = TsdbRollup(
    name = "receiptByDay",
    filter = None,
    groupBy = Tables.receiptTable.dimensionSeq.map(d => DimensionExpr(d.aux)),
    fields = baseRollupFields ++ shiftRollupFields ++ additionalRollupFieldsFromDetails,
    fromTable = Tables.receiptTable,
    toTables = Seq(Tables.receiptByDayTable),
    timeExpr = TruncDayExpr(TimeExpr)
  )

  val receiptDayAllKkmsRollup = TsdbRollup(
    name = "receiptByDayAllKkms",
    filter = None,
    groupBy = Seq.empty,
    fields = summaryRollupFields ++ additionalRollupFieldsFromRollups,
    fromTable = Tables.receiptByDayTable,
    toTables = Seq(Tables.receiptByDayAllKkmsTable),
    timeExpr = TruncDayExpr(TimeExpr)
  )

  val receiptWeekRollup = TsdbRollup(
    name = "receiptByWeek",
    filter = None,
    groupBy = Seq(dimension(Dimensions.KKM_ID), dimension(Dimensions.OPERATION_TYPE)),
    fields = baseRollupFields ++ additionalRollupFieldsFromRollups,
    fromTable = Tables.receiptByDayTable,
    toTables = Seq(Tables.receiptByWeekTable),
    timeExpr = TruncWeekExpr(TimeExpr)
  )

  val receiptMonthRollup = TsdbRollup(
    name = "receiptByMonth",
    filter = None,
    groupBy = Seq(dimension(Dimensions.KKM_ID), dimension(Dimensions.OPERATION_TYPE)),
    fields = baseRollupFields ++ additionalRollupFieldsFromRollups,
    fromTable = Tables.receiptByDayTable,
    toTables = Seq(Tables.receiptByMonthTable),
    timeExpr = TruncMonthExpr(TimeExpr)
  )

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy