Найти среднее время между несколькими объектами datetime mongodb - PullRequest
0 голосов
/ 03 мая 2018

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

{
  "_id": ObjectId("5aea9f9a83b391f80e00a1b1"),
  "Client": "ABC",
  "Timestamp": "2018-05-03 10:47:42"
 },
{
  "_id": ObjectId("5aea9f9a83b391f80e00c1a1"),
  "Client": "ABC",
  "Timestamp": "2018-05-03 11:05:04"
 }  ,
{
  "_id": ObjectId("5aea9f9a83b391f80e00a1e1"),
  "Client": "ABC",
  "Timestamp": "2018-05-03 13:05:04"
 }  ,
{
  "_id": ObjectId("5aea9f9a83b391f80eaea1e1"),
  "Client": "DEF",
  "Timestamp": "2018-05-03 11:20:44"
 }  

Я только что попробовал код в codeigniter

$optn = array(
        array('$group' => array( '_id' => '$Client', 'date1' => array('$min' => '$Timestamp'), 'date2' => array('$max' => '$Timestamp'), 'avg_time' => array('$avg' =>  array('$subtract' => array('$date2', '$date1')))))
    );
$repeatdata = $this->mongo_db->aggregate("logsdata", $optn);
echo '<pre>';  print_r($repeatdata);

Это дает мне результат как:

 Array
    (
[waitedMS] => 0
[result] => Array
    (
        [0] => Array
            (
                [_id] => ABC
                [date1] => 2018-05-03 10:47:42
                [date2] => 2018-05-03 13:05:04
                [avg_time] => 
            )

        [1] => Array
            (
                [_id] => DEF
                [date1] => 2018-05-03 11:20:44
                [date2] => 2018-05-03 11:20:44
                [avg_time] => 
            )
     )
  )
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...