校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > 基于Morphia實(shí)現(xiàn)MongoDB按小時(shí)、按天聚合操作方法

基于Morphia實(shí)現(xiàn)MongoDB按小時(shí)、按天聚合操作方法

熱門(mén)標(biāo)簽:內(nèi)蒙古營(yíng)銷智能外呼系統(tǒng)哪個(gè)好 呼和浩特外呼系統(tǒng)原理是什么 青白江400企業(yè)電話申請(qǐng) crm外呼系統(tǒng)聯(lián)系方式 智能外呼系統(tǒng)官網(wǎng) 長(zhǎng)沙電銷外呼防封卡是什么 小裙科技電銷機(jī)器人怎樣 外呼線路資源屬于電信業(yè)務(wù)嗎 河南電話外呼系統(tǒng)招商

MongoDB按照天數(shù)或小時(shí)聚合

需求

最近接到需求,需要對(duì)用戶賬戶下的設(shè)備狀態(tài),分別按照天以及小時(shí)進(jìn)行聚合,以此為基礎(chǔ)繪制設(shè)備狀態(tài)趨勢(shì)圖.
實(shí)現(xiàn)思路是啟動(dòng)定時(shí)任務(wù),對(duì)各用戶的設(shè)備狀態(tài)數(shù)據(jù)分別按照小時(shí)以及天進(jìn)行聚合,并存儲(chǔ)進(jìn)數(shù)據(jù)庫(kù)中供用戶后續(xù)查詢.
涉及到的技術(shù)棧分別為:Spring Boot,MongoDB,Morphia.

數(shù)據(jù)模型

@Data
@Builder
@Entity(value = "rawDevStatus", noClassnameStored = true)
// 設(shè)備狀態(tài)索引
@Indexes({
    // 設(shè)置數(shù)據(jù)超時(shí)時(shí)間(TTL,MongoDB根據(jù)TTL在后臺(tái)進(jìn)行數(shù)據(jù)刪除操作)
    @Index(fields = @Field("time"), options = @IndexOptions(expireAfterSeconds = 3600 * 24 * 72)),
    @Index(fields = {@Field("userId"), @Field(value = "time", type = IndexType.DESC)})
})
public class RawDevStatus {
  @Id
  @JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
  private ObjectId objectId;
  private String userId;
  private Instant time;
  @Embedded("points")
  ListPoint> protocolPoints;
  @Data
  @AllArgsConstructor
  public static class Point {
    /**
     * 協(xié)議類型
     */
    private Protocol protocol;
    /**
     * 設(shè)備總數(shù)
     */
    private Integer total;
    /**
     * 設(shè)備在線數(shù)目
     */
    private Integer onlineNum;
    /**
     * 處于啟用狀態(tài)設(shè)備數(shù)目
     */
    private Integer enableNum;
  }
}

上述代碼是設(shè)備狀態(tài)實(shí)體類,其中設(shè)備狀態(tài)數(shù)據(jù)是按照設(shè)備所屬協(xié)議進(jìn)行區(qū)分的.

@Data
@Builder
@Entity(value = "aggregationDevStatus", noClassnameStored = true)
@Indexes({
    @Index(fields = @Field("expireAt"), options = @IndexOptions(expireAfterSeconds = 0)),
    @Index(fields = {@Field("userId"), @Field(value = "time", type = IndexType.DESC)})
})
public class AggregationDevStatus {
  @Id
  @JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
  private ObjectId objectId;
  /**
   * 用戶ID
   */
  private String userId;
  /**
   * 設(shè)備總數(shù)
   */
  private Double total;
  /**
   * 設(shè)備在線數(shù)目
   */
  private Double onlineNum;
  /**
   * 處于啟用狀態(tài)設(shè)備數(shù)目
   */
  private Double enableNum;
  /**
   * 聚合類型(按照小時(shí)還是按照天聚合)
   */
  @Property("aggDuration")
  private AggregationDuration aggregationDuration;
  private Instant time;
  /**
   * 動(dòng)態(tài)設(shè)置文檔過(guò)期時(shí)間
   */
  private Instant expireAt;
}

上述代碼是期待的聚合結(jié)果,其中構(gòu)建兩個(gè)索引:(1)超時(shí)索引;(2)復(fù)合索引,程序會(huì)根據(jù)用戶名以及時(shí)間查詢?cè)O(shè)備狀態(tài)聚合結(jié)果.

聚合操作符介紹

聚合操作類似于管道,管道中的每一步操作產(chǎn)生的中間結(jié)果作為下一步的輸入源,最終輸出聚合結(jié)果.

此次聚合主要涉及以下操作:

•$project:指定輸出文檔中的字段.
•$unwind:拆分?jǐn)?shù)據(jù)中的數(shù)組;
•match:選擇要處理的文檔數(shù)據(jù);
•group:根據(jù)key分組聚合結(jié)果.

原始聚合語(yǔ)句

db.getCollection('raw_dev_status').aggregate([
  {$match:
    {
      time:{$gte: ISODate("2019-06-27T00:00:00Z")},
    }
  },
  {$unwind: "$points"},
  {$project:
    {
      userId:1,points:1,
      tmp: {$dateToString: { format: "%Y:%m:%dT%H:00:00Z", date: "$time" } }
    }
  },
  {$project:
    {
      userId:1,points:1,
      groupTime: {$dateFromString: { dateString: "$tmp", format: "%Y:%m:%dT%H:%M:%SZ", } }
    }
  },
  {$group:
    {
      _id:{user_id:'$userId', cal_time:'$groupTime'},
      devTotal:{'$avg':'$points.total'},
      onlineTotal:{'$avg':'$points.onlineNum'},
      enableTotal:{'$avg':'$points.enableNum'}
    }
  },
])

上述代碼是按小時(shí)聚合數(shù)據(jù),以下來(lái)逐步介紹處理思路:

(1) $match

根據(jù)小時(shí)聚合數(shù)據(jù),因?yàn)橹恍枰@取近24小時(shí)的聚合結(jié)果,所以對(duì)數(shù)據(jù)進(jìn)行初步篩選.

(2) $unwind

raw_dev_status中的設(shè)備狀態(tài)是按照協(xié)議區(qū)分的數(shù)組,因此需要對(duì)其進(jìn)行展開(kāi),以便下一步進(jìn)行篩選;

(3) $project

  {$project:
    {
      userId:1,points:1,
      tmp: {$dateToString: { format: "%Y:%m:%dT%H:00:00Z", date: "$time" } }
    }
  }

選擇需要輸出的數(shù)據(jù),分別為:userId,points以及tmp.

需要注意,為了按照時(shí)間聚合,對(duì)$time屬性進(jìn)行操作,提取%Y:%m:%dT%H時(shí)信息至$tmp作為下一步的聚合依據(jù).

如果需要按天聚合,則format數(shù)據(jù)可修改為:%Y:%m:%dT00:00:00Z即可滿足要求.

(4) $project

  {$project:
    {
      userId:1,points:1,
      groupTime: {$dateFromString: { dateString: "$tmp", format: "%Y:%m:%dT%H:%M:%SZ", } }
    }
  }

因?yàn)樯弦徊絧roject操作中,tmp為字符串?dāng)?shù)據(jù),最終的聚合結(jié)果需要時(shí)間戳(主要懶,不想在程序中進(jìn)行轉(zhuǎn)換操作).
因此,此處對(duì)$tmp進(jìn)行操作,轉(zhuǎn)換為時(shí)間類型數(shù)據(jù),即groupTime.

(5) $group

對(duì)聚合結(jié)果進(jìn)行分類操作,并生成最終輸出結(jié)果.

 {$group:
    {
      # 根據(jù)_id進(jìn)行分組操作,依據(jù)是`user_id`以及`$groupTime`
      _id:{user_id:'$userId', cal_time:'$groupTime'},
      # 求設(shè)備總數(shù)平均值
      devTotal:{'$avg':'$points.total'},
      # 求設(shè)備在線數(shù)平均值
      onlineTotal:{'$avg':'$points.onlineNum'},
      # ...
      enableTotal:{'$avg':'$points.enableNum'}
    }
  }

代碼編寫(xiě)

此處ODM選擇Morphia,亦可以使用MongoTemplate,原理類似.

 /**
   * 創(chuàng)建聚合條件
   *
   * @param pastTime   過(guò)去時(shí)間段
   * @param dateToString 格式化字符串(%Y:%m:%dT%H:00:00Z或%Y:%m:%dT00:00:00Z)
   * @return 聚合條件
   */
  private AggregationPipeline createAggregationPipeline(Instant pastTime, String dateToString, String stringToDate) {
    QueryRawDevStatus> query = datastore.createQuery(RawDevStatus.class);
    return datastore.createAggregation(RawDevStatus.class)
        .match(query.field("time").greaterThanOrEq(pastTime))
        .unwind("points", new UnwindOptions().preserveNullAndEmptyArrays(false))
        .match(query.field("points.protocol").equal("ALL"))
        .project(Projection.projection("userId"),
            Projection.projection("points"),
            Projection.projection("convertTime",
                Projection.expression("$dateToString",
                    new BasicDBObject("format", dateToString)
                        .append("date", "$time"))
            )
        )
        .project(Projection.projection("userId"),
            Projection.projection("points"),
            Projection.projection("convertTime",
                Projection.expression("$dateFromString",
                    new BasicDBObject("format", stringToDate)
                        .append("dateString", "$convertTime"))
            )
        )
        .group(
            Group.id(Group.grouping("userId"), Group.grouping("convertTime")),
            Group.grouping("total", Group.average("points.total")),
            Group.grouping("onlineNum", Group.average("points.onlineNum")),
            Group.grouping("enableNum", Group.average("points.enableNum"))
        );
  }
  /**
   * 獲取聚合結(jié)果
   *
   * @param pipeline 聚合條件
   * @return 聚合結(jié)果
   */
  private ListAggregationMidDevStatus> getAggregationResult(AggregationPipeline pipeline) {
    ListAggregationMidDevStatus> statuses = new ArrayList>();
    IteratorAggregationMidDevStatus> resultIterator = pipeline.aggregate(
        AggregationMidDevStatus.class, AggregationOptions.builder().allowDiskUse(true).build());
    while (resultIterator.hasNext()) {
      statuses.add(resultIterator.next());
    }
    return statuses;
  }
  //......................................................................................
  // 獲取聚合結(jié)果(省略若干代碼)
  AggregationPipeline pipeline = createAggregationPipeline(pastTime, dateToString, stringToDate);
  ListAggregationMidDevStatus> midStatuses = getAggregationResult(pipeline);
  if (CollectionUtils.isEmpty(midStatuses)) {
    log.warn("Can not get dev status aggregation result.");
    return;
  }

總結(jié)

以上所述是小編給大家介紹的基于Morphia實(shí)現(xiàn)MongoDB按小時(shí)、按天聚合操作方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

您可能感興趣的文章:
  • JAVA mongodb 聚合幾種查詢方式詳解
  • Mongodb中MapReduce實(shí)現(xiàn)數(shù)據(jù)聚合方法詳解
  • Mongodb聚合函數(shù)count、distinct、group如何實(shí)現(xiàn)數(shù)據(jù)聚合操作
  • MongoDB教程之聚合(count、distinct和group)
  • MongoDB聚合功能淺析

標(biāo)簽:菏澤 白山 池州 楚雄 安順 舟山 黃石 呼倫貝爾

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《基于Morphia實(shí)現(xiàn)MongoDB按小時(shí)、按天聚合操作方法》,本文關(guān)鍵詞  基于,Morphia,實(shí)現(xiàn),MongoDB,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《基于Morphia實(shí)現(xiàn)MongoDB按小時(shí)、按天聚合操作方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于基于Morphia實(shí)現(xiàn)MongoDB按小時(shí)、按天聚合操作方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    26uuu色噜噜精品一区| 色婷婷亚洲精品| 精品福利一区二区三区| 欧美一区二区精品久久911| 91精品国产综合久久国产大片| 一区二区三区中文在线| 六月婷婷色综合| 91 com成人网| 一个色综合av| 日本成人在线不卡视频| jvid福利写真一区二区三区| 国产九色精品成人porny| 色哟哟国产精品免费观看| 亚洲品质自拍视频| 韩国v欧美v日本v亚洲v| 91在线小视频| 亚洲天堂成人网| 成人高清av在线| 久久久久国产一区二区三区四区| 欧美三级日本三级少妇99| 精品国产乱码久久久久久免费 | 色视频一区二区| 亚洲国产精品精华液2区45| 国产精品12区| 精品少妇一区二区三区视频免付费| 亚洲综合偷拍欧美一区色| 蜜桃av一区二区在线观看| 色综合久久天天| ㊣最新国产の精品bt伙计久久| 国内精品嫩模私拍在线| 26uuu精品一区二区| 亚洲自拍偷拍欧美| 色就色 综合激情| 成人免费视频在线观看| 成人国产免费视频| 欧美精品一区二区三区蜜桃视频| 亚洲日本va午夜在线电影| 成人网页在线观看| 国产婷婷色一区二区三区| 国产aⅴ综合色| 正在播放亚洲一区| 精品国产乱码久久久久久牛牛 | 亚洲主播在线观看| 成人av网站在线观看免费| 精品国产免费一区二区三区香蕉| 午夜免费久久看| 国产亚洲精品中文字幕| 国产精品一区二区黑丝| 欧美大黄免费观看| 亚洲五月六月丁香激情| 91精品国产麻豆国产自产在线| 亚洲一线二线三线视频| 在线这里只有精品| 国产精品久久久久久一区二区三区| 老司机精品视频在线| 久久综合九色综合欧美98 | 日日夜夜免费精品| 高清不卡一区二区| 国产精品成人在线观看| 色婷婷亚洲精品| 日韩美女精品在线| 一本色道久久综合精品竹菊| 亚洲一区二区在线视频| 欧美大片在线观看| 粉嫩13p一区二区三区| 亚洲靠逼com| 欧美一区二区三区婷婷月色| 日韩av午夜在线观看| 国产人成一区二区三区影院| 欧美三级中文字| 97成人超碰视| 久久99精品国产| 午夜精品免费在线观看| 国产精品国产自产拍在线| 91亚洲国产成人精品一区二区三| 精品一区二区三区免费毛片爱| 国产精品人人做人人爽人人添| 欧美在线制服丝袜| 一区二区三区欧美亚洲| 亚洲视频一区二区在线| 欧美一区二区免费视频| 精品亚洲aⅴ乱码一区二区三区| 国产日韩欧美电影| 欧美精品一区二区三区蜜桃视频 | 欧美成人精品二区三区99精品| 91老师国产黑色丝袜在线| 亚洲一区欧美一区| 一区二区三区四区五区视频在线观看| 国产精品美女视频| 欧美一区二区三区免费在线看| 色综合欧美在线视频区| 亚洲日本青草视频在线怡红院| 欧美日韩在线一区二区| 在线中文字幕一区二区| 欧美日韩国产一区二区三区地区| 欧洲视频一区二区| 99视频精品全部免费在线| 日韩一区欧美二区| 久久se精品一区精品二区| 久久国产生活片100| 国内不卡的二区三区中文字幕 | 欧美三区免费完整视频在线观看| 国产伦精一区二区三区| 97se狠狠狠综合亚洲狠狠| 成人免费观看视频| 成人激情午夜影院| 午夜精品免费在线观看| 亚洲精品视频一区二区| 亚洲国产cao| 亚洲一区二区三区四区五区黄 | 国产女人18水真多18精品一级做| 午夜免费久久看| 亚洲sss视频在线视频| 七七婷婷婷婷精品国产| 另类调教123区| 国产精品一区免费在线观看| 粉嫩久久99精品久久久久久夜| 欧洲精品在线观看| 欧美精选午夜久久久乱码6080| 国产精品久久久久久久久晋中| 精品国产乱码久久久久久浪潮| 欧美日韩在线亚洲一区蜜芽| 日韩三级在线免费观看| 欧美国产1区2区| 亚洲一区二区三区视频在线| 亚洲第一成人在线| 国产成人亚洲综合a∨猫咪| 欧美日韩亚洲高清一区二区| 欧美日韩国产精品自在自线| 91精品国产全国免费观看| 国产精品久久久久一区| 久久久久久久久久久久久久久99 | 久久成人免费日本黄色| 国产精品一区在线观看你懂的| 色94色欧美sute亚洲13| 欧美大片拔萝卜| 亚洲精品在线三区| 国产精品丝袜一区| 欧美成人一区二区三区| 麻豆精品国产91久久久久久| 成人av在线播放网站| 在线观看av一区二区| 亚洲欧美自拍偷拍| 国产成人一级电影| 日韩一级精品视频在线观看| 欧美96一区二区免费视频| 成人自拍视频在线| 日韩成人dvd| 亚洲二区在线视频| 亚洲国产精品激情在线观看| 精品久久久久久最新网址| 欧美伊人久久久久久久久影院| 99免费精品在线| 免费一级欧美片在线观看| 精品一区二区三区av| 精品一区二区免费| 欧美一区二区三区男人的天堂| 亚洲图片欧美激情| 久久精品一区八戒影视| 日韩精品中午字幕| 欧美三级乱人伦电影| 99天天综合性| 国产一区二区三区免费观看| 青青草原综合久久大伊人精品| 久久国产剧场电影| 91网页版在线| 国产91丝袜在线播放0| 色综合久久综合网欧美综合网| 国产精品久久精品日日| 欧美tickling网站挠脚心| 在线视频你懂得一区二区三区| 成人亚洲一区二区一| 国产福利一区在线观看| 国产成人精品免费一区二区| 国内偷窥港台综合视频在线播放| 另类小说图片综合网| 亚洲国产aⅴ成人精品无吗| 亚洲人成精品久久久久久| 欧美极品另类videosde| 在线精品观看国产| 2017欧美狠狠色| 色综合天天综合色综合av | 99re66热这里只有精品3直播 | 91国偷自产一区二区开放时间 | 日韩福利视频网| 一区二区三区在线观看视频| 69av一区二区三区| 欧美色电影在线| 一本大道久久a久久综合 | 色婷婷综合久久| 91麻豆123| 色屁屁一区二区| 99久久久久久99| 成人黄色免费短视频| 精品一区免费av| 韩国av一区二区三区四区 | 日韩一区和二区| 国产大片一区二区| 成人高清视频在线观看| 久久成人久久爱|