欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDB聚合運算符$dateFromString詳解

 更新時間:2024年03月07日 15:18:15   作者:原子星  
$dateFromString聚合運算符將日期時間字符串轉(zhuǎn)換為日期對象,本文給大家介紹MongoDB聚合運算符$dateFromString的相關(guān)知識,感興趣的朋友跟隨小編一起看看吧

$dateFromString聚合運算符將日期時間字符串轉(zhuǎn)換為日期對象。

語法

{ $dateFromString: {
     dateString: <dateStringExpression>,
     format: <formatStringExpression>,
     timezone: <tzExpression>,
     onError: <onErrorExpression>,
     onNull: <onNullExpression>
} }

參數(shù)字段說明:

字段必須說明
dateString如果沒有用isoWeekYear則必須日歷年度,可以是任何能解析為整數(shù)的表達(dá)式,值域為:1~9999,如果超出范圍將報錯。從4.4以后最小值為1,再之前的版本最小值是0
format若year沒有用則必須ISO的周日期年,可以是任何能解析為整數(shù)的表達(dá)式,值域為:1~9999,如果超出將報錯。從4.4以后最小值為1,再之前的版本最小值是0
timezone可選執(zhí)行操作的時區(qū),<timezone>可以是任何能被解析為:Olson時區(qū)標(biāo)識符或UTC偏移量
onError可選在解析dateString時如果出錯,則輸出onError表達(dá)式的結(jié)果,結(jié)果值可以是任意類型
onNull可選如果dateStringnull或不存在,則輸出onNull表達(dá)式的結(jié)果,可以是任意類型

使用

使用例子對規(guī)則進行說明

例1:

{ $dateFromString: {
    dateString: "2017-02-08T12:10:40.787"
} }

結(jié)果:ISODate("2017-02-08T12:10:40.787Z")

例2:

{ $dateFromString: {
     dateString: "2017-02-08T12:10:40.787",
     timezone: "America/New_York"
} }

結(jié)果:ISODate("2017-02-08T12:10:40.787Z")

例3:

{ $dateFromString: {
     dateString: "2017-02-08"
} }

結(jié)果:ISODate("2017-02-08T00:00:00Z")

例4:

{ $dateFromString: {
     dateString: "oct 20 2020"
} }

結(jié)果:ISODate("2020-10-20T00:00:00.000Z")

例5:

{ $dateFromString: {
     dateString: "06-15-2018",
     format: "%m-%d-%Y"
} }

結(jié)果:ISODate("2018-06-15T00:00:00Z")

例6:

{ $dateFromString: {
     dateString: "15-06-2018",
     format: "%d-%m-%Y"
} }

結(jié)果:ISODate("2018-06-15T00:00:00Z")

{ $dateFromString: {
     dateString: "WED jan 31 12:05:28 +03:30 1996"
} }

結(jié)果:ISODate("1996-01-31T08:35:28.000Z")

格式指示符

指示符描述可能的值
%b月份縮寫(3個字符)jan, feb, mar, apr, may, jun, jul, aug, sep, oct, nov, dec
%B完整月份january-december
%d一個月內(nèi)的第幾天(2個數(shù)字,0填充)01-31
%GISO8601格式 年0000-9999
%H小時(2個數(shù)字,0填充,24小時時鐘)00-23
%j一年內(nèi)的第幾天(3個數(shù)字,0填充)001-366
%L毫秒(3個數(shù)字,0填充)000=999
%m月(2個數(shù)字,0填充)01-12
%M分鐘(2個數(shù)字,0填充)00-59
%S秒(2個數(shù)字,0填充)00-60
%uISO8601格式的一周內(nèi)的第幾天1-7
%U一年內(nèi)的第幾周(2個數(shù)字,0填充)00-53
%VISO8601格式的一年內(nèi)的第幾周1-53
%w一周內(nèi)的第幾天(整數(shù),0-Sunday,6-Saturday)0-6
%Y年(4個數(shù)字,0填充)0000-9999
%z時區(qū)與UTC的偏移量+/-[hh][mm]
%Z從 UTC 開始的分鐘偏移量,用數(shù)字表示。例如,如果時區(qū)偏移(+/-[hhmm])為 +0445,則分鐘偏移為+285。+/-mmm
%%百分比字符作為字面值%

舉例

日期轉(zhuǎn)換

集合logmessages包含下面的數(shù)據(jù):

{ _id: 1, date: "2017-02-08T12:10:40.787", timezone: "America/New_York", message:  "Step 1: Started" },
{ _id: 2, date: "2017-02-08", timezone: "-05:00", message:  "Step 1: Ended" },
{ _id: 3, message:  " Step 1: Ended " },
{ _id: 4, date: "2017-02-09", timezone: "Europe/London", message: "Step 2: Started"},
{ _id: 5, date: "2017-02-09T03:35:02.055", timezone: "+0530", message: "Step 2: In Progress"}

下面的聚合使用$dateFromString將日期值轉(zhuǎn)換為日期對象:

db.logmessages.aggregate( [ {
   $project: {
      date: {
         $dateFromString: {
            dateString: '$date',
            timezone: 'America/New_York'
         }
      }
   }
} ] )

上述匯總返回以下文檔,并將每個日期字段轉(zhuǎn)換為東部時區(qū):

{ "_id" : 1, "date" : ISODate("2017-02-08T17:10:40.787Z") }
{ "_id" : 2, "date" : ISODate("2017-02-08T05:00:00Z") }
{ "_id" : 3, "date" : null }
{ "_id" : 4, "date" : ISODate("2017-02-09T05:00:00Z") }
{ "_id" : 5, "date" : ISODate("2017-02-09T08:35:02.055Z") }

也可以通過文檔字段提供時區(qū)參數(shù),而不是硬編碼參數(shù)。例如:

db.logmessages.aggregate( [ {
   $project: {
      date: {
         $dateFromString: {
            dateString: '$date',
            timezone: '$timezone'
         }
      }
   }
} ] )

上述匯總返回以下文檔,并將每個date字段轉(zhuǎn)換為各自的 UTC 表示形式。

{ "_id" : 1, "date" : ISODate("2017-02-08T17:10:40.787Z") }
{ "_id" : 2, "date" : ISODate("2017-02-08T05:00:00Z") }
{ "_id" : 3, "date" : null }
{ "_id" : 4, "date" : ISODate("2017-02-09T00:00:00Z") }
{ "_id" : 5, "date" : ISODate("2017-02-08T22:05:02.055Z") }

錯誤處理onError

如果文檔集中包含不可解析日期字符串的文檔,則$dateFromString會出錯,除非給參數(shù)onError提供一個聚合表達(dá)式。

例如,給定一個包含以下文檔的日期集合:

{ "_id" : 1, "date" : "2017-02-08T12:10:40.787", timezone: "America/New_York" },
{ "_id" : 2, "date" : "20177-02-09T03:35:02.055", timezone: "America/New_York" }

可以使用onError參數(shù)以原始字符串形式返回?zé)o效日期:

db.dates.aggregate( [ {
   $project: {
      date: {
         $dateFromString: {
            dateString: '$date',
            timezone: '$timezone',
            onError: '$date'
         }
      }
   }
} ] )

返回的文檔如下:

{ "_id" : 1, "date" : ISODate("2017-02-08T17:10:40.787Z") }
{ "_id" : 2, "date" : "20177-02-09T03:35:02.055" }

空值的粗粒 onNull

如果集合文檔包含空日期字符串,$dateFromString返回空,除非給onNull指定一個聚合表達(dá)式。

例如,集合dates有以下文檔:

{ "_id" : 1, "date" : "2017-02-08T12:10:40.787", timezone: "America/New_York" },
{ "_id" : 2, "date" : null, timezone: "America/New_York" }

可以使用onNUll參數(shù)讓$dateFromString返回代表unix紀(jì)元的日期,而不是空值:

db.dates.aggregate( [ {
   $project: {
      date: {
         $dateFromString: {
            dateString: '$date',
            timezone: '$timezone',
            onNull: new Date(0)
         }
      }
   }
} ] )

返回下面的結(jié)果:

{ "_id" : 1, "date" : ISODate("2017-02-08T17:10:40.787Z") }
{ "_id" : 2, "date" : ISODate("1970-01-01T00:00:00Z") }

到此這篇關(guān)于MongoDB聚合運算符:$dateFromString的文章就介紹到這了,更多相關(guān)MongoDB $dateFromString內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mongo DB增刪改查命令

    Mongo DB增刪改查命令

    本文給大家匯總介紹了一下Mongo DB數(shù)據(jù)庫的增刪改查命令以及部分的示例,有需要的小伙伴可以參考下,希望對大家學(xué)習(xí)Mongo DB能夠有所幫助
    2016-12-12
  • MongoDB高可用與分片

    MongoDB高可用與分片

    最近項目在使用MongoDB作為圖片和文檔的存儲數(shù)據(jù)庫,為啥不直接存MySQL里,還要搭個MongoDB集群,麻不麻煩?讓我們一起,一探究竟,繼續(xù)學(xué)習(xí)MongoDB高可用和片鍵策略,實現(xiàn)快速入門,感興趣的小伙伴可以參考閱讀
    2023-04-04
  • MongoDB通過查詢與游標(biāo)徹底玩轉(zhuǎn)分布式文件存儲

    MongoDB通過查詢與游標(biāo)徹底玩轉(zhuǎn)分布式文件存儲

    MongoDB最大的特點是它支持的查詢語言非常強大,其語法有點類似于面向?qū)ο蟮牟樵冋Z言,幾乎可以實現(xiàn)類似關(guān)系數(shù)據(jù)庫單表查詢的絕大部分功能,而且還支持對數(shù)據(jù)建立索引,這篇文章主要介紹了MongoDB查詢與游標(biāo),徹底玩轉(zhuǎn)分布式文件存儲,需要的朋友可以參考下
    2023-01-01
  • MongoDB集合中的文檔管理

    MongoDB集合中的文檔管理

    這篇文章介紹了MongoDB集合中文檔的管理方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • MongoDB詭異問題之sh.stopBalancer卡住的解決方法

    MongoDB詭異問題之sh.stopBalancer卡住的解決方法

    這篇文章主要給大家介紹了關(guān)于MongoDB詭異問題之sh.stopBalancer卡住解決的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • CentOS7下安裝MongoDB數(shù)據(jù)庫過程

    CentOS7下安裝MongoDB數(shù)據(jù)庫過程

    大家好,本篇文章主要講的是CentOS7下安裝MongoDB數(shù)據(jù)庫過程,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • MongoDB和mysql的區(qū)別對比分析

    MongoDB和mysql的區(qū)別對比分析

    MongoDB?是一個基于分布式文件存儲的數(shù)據(jù)庫,而MySQL?是一款安全、跨平臺、高效的,并與?PHP、Java?等主流編程語言緊密結(jié)合的數(shù)據(jù)庫系統(tǒng),本文重點給大家介紹MongoDB和mysql的區(qū)別,需要的朋友可以參考下
    2023-01-01
  • MongoDB服務(wù)端JavaScript腳本使用方法

    MongoDB服務(wù)端JavaScript腳本使用方法

    這篇文章主要介紹了MongoDB服務(wù)端JavaScript腳本使用方法,需要的朋友可以參考下
    2015-10-10
  • MongoDB數(shù)據(jù)更新方法干貨篇

    MongoDB數(shù)據(jù)更新方法干貨篇

    之前給大家分享了MongoDB中數(shù)據(jù)查詢的相關(guān)方法和技巧,那么下面這篇文章主要給大家介紹了MongoDB中數(shù)據(jù)更新方法的相關(guān)資料,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-05-05
  • MongoDB安裝到windows服務(wù)的方法及遇到問題的完美解決方案

    MongoDB安裝到windows服務(wù)的方法及遇到問題的完美解決方案

    這篇文章主要介紹了MongoDB安裝到windows服務(wù)的方法及遇到問題的完美解決方案,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2016-11-11

最新評論