Выбрать строки в многоуровневых отчетах

Чтобы выбрать строки в многоуровневых отчетах (или в обычных без группировки), нужно использовать команду report/select_result_rows:

svc=report/select_result_rows&params={"tableIndex":<int>,
				      "config":{
				      		"type":<text>,
				      		"data":{}
				      }}

:!: Использование данного запроса рассмотрено в примере Отчеты.

Параметры

Название Описание
tableIndex индекс таблицы
config конфигурация
type тип запроса:
range - последовательность строк;
row - строка
data данные для конфигурации

Если параметр type равен range, то data имеет следующий формат:

"data":{
	"from":<uint>,
	"to":<uint>,
	"level":<uint>,
	"flat":<int>,
	"rawValues":<int>,
	"unitInfo":<int>
}

Где,

  • from - индекс первой строки;
  • to - индекс последней строки;
  • level - уровень вложенности;
  • flat - вложенные уровни на одном уровне с родительскими: 0 - нет, 1 - да (необязательный параметр);
  • rawValues - отображать параметры v, vt: 0 - нет, 1 - да (необязательный параметр);
  • unitInfo - получить id объекта: 0 - нет, 1 - да

Если параметр type равен row, то data имеет следующий формат:

"data":{
	"rows":[<int>],
	"level":<uint>,
	"flat":<int>,
	"from":<uint>,
	"to":<uint>
}

Где,

  • rows - индекс строки (можно указывать индекс вложенной строки до предпоследнего уровня вложенности);
  • level - уровень вложенности;
  • flat - вложенные уровни на одном уровне с родительскими: 0 - нет, 1 - да (необязательный параметр);
  • from - индекс первой вложенной строки (необязательный параметр);
  • to - индекс последней вложенной строки (необязательный параметр).

Возвращаемый результат

[
	{
		"n":<uint>,	/* индекс строки (от 0) */
		"i1":<uint>,	/* номер первого сообщения в заданном интервале */
		"i2":<uint>,	/* номер последнего сообщения в заданном интервале */
		"t1":<uint>,	/* время первого сообщения в заданном интервале */
		"t2":<uint>,	/* время последнего сообщения в заданном интервале */
		"d":<int>,	/* количество строк следующего уровня вложенности */
		"c":[		/* массив ячеек */
			<text>,		/* значение ячейки текстовое */
			{		/* или объект */
				"t":<text>,	/* форматированное значение ячейки */
				"v":<double>,	/* исходное значение ячейки */
				"vt":<double>,	/* тип значения */
				"pi": {	/* подэлементы */
					"t":<text>,	/* тип подэлементов */
					"ids": [ 	/* массив ID подэлементов */	
					]
				},
				"y":<double>,	/* широта */
				"x":<double>	/* долгота */
			}			
		],
		"r":[		/* содержит подстроки соответствующие уровню вложенности указанному при запросе */
			{		/* набор полей у подстроки будет такой же как и у родительской строки */
				"n":<uint>,
				"i1":<uint>,
				"i2":<uint>,
				...
			}
		]
	}
]

:!: Типы значений описаны в в этой статье.

Follow us on Facebook Gurtam Wialon Twitter Gurtam Wialon info@gurtam.com   |   Copyright © 2002-2025 Gurtam