aggregateByLabel(self::DEVICE_TYPE_FIELD, self::DEVICE_TYPE_RECORD_NAME); $this->aggregateByLabel(self::DEVICE_BRAND_FIELD, self::DEVICE_BRAND_RECORD_NAME); $this->aggregateByLabel(self::DEVICE_MODEL_FIELD, self::DEVICE_MODEL_RECORD_NAME); $this->aggregateByLabel(self::OS_FIELD, self::OS_RECORD_NAME); $this->aggregateByLabel(self::OS_VERSION_FIELD, self::OS_VERSION_RECORD_NAME); $this->aggregateByLabel(self::BROWSER_FIELD, self::BROWSER_RECORD_NAME); $this->aggregateByLabel(self::BROWSER_ENGINE_FIELD, self::BROWSER_ENGINE_RECORD_NAME); $this->aggregateByLabel(self::BROWSER_VERSION_DIMENSION, self::BROWSER_VERSION_RECORD_NAME); } public function aggregateMultipleReports() { $dataTablesToSum = array( self::DEVICE_TYPE_RECORD_NAME, self::DEVICE_BRAND_RECORD_NAME, self::DEVICE_MODEL_RECORD_NAME, self::OS_RECORD_NAME, self::OS_VERSION_RECORD_NAME, self::BROWSER_RECORD_NAME, self::BROWSER_ENGINE_RECORD_NAME, self::BROWSER_VERSION_RECORD_NAME ); $columnsAggregationOperation = null; foreach ($dataTablesToSum as $dt) { $this->getProcessor()->aggregateDataTableRecords( $dt, $this->maximumRows, $this->maximumRows, $columnToSort = 'nb_visits', $columnsAggregationOperation, $columnsToRenameAfterAggregation = null, $countRowsRecursive = array()); } } private function aggregateByLabel($labelSQL, $recordName) { $metrics = $this->getLogAggregator()->getMetricsFromVisitByDimension($labelSQL)->asDataTable(); $report = $metrics->getSerialized($this->maximumRows, null, Metrics::INDEX_NB_VISITS); $this->getProcessor()->insertBlobRecord($recordName, $report); } }