Uploaded image for project: 'Core Server'
  1. Core Server
  2. SERVER-60641

Return better error message when trying to shard time series collection using hashed timefield

    • Type: Icon: Improvement Improvement
    • Resolution: Fixed
    • Priority: Icon: Major - P3 Major - P3
    • 7.1.0-rc0
    • Affects Version/s: None
    • Component/s: None
    • Query Integration
    • Fully Compatible
    • QI 2023-06-12
    • None
    • None
    • None
    • None
    • None
    • None
    • None

       

      db.runCommand({ create: "tscoll", timeseries:{timeField: 'time', metaField: 'id' }})                                                           

      db.adminCommand({ shardCollection: "test.tscoll", key:

      { time: "hashed" }

      , numInitialChunks: 6 } )                                                                                                                                     **                                                                                                                                                                                                                                                                     returns               

      {                                                                                                                                                       "ok" : 0,                                                                                                                                       "errmsg" : "Invalid index spec for time-series collection: \{ time: \"hashed\" }

      . Indexes on the time field must be ascending or descen\

      ding (numbers only): time: \"hashed\"",                                                                                                        

              "code" : 2,                                                                                                                            

              "codeName" : "BadValue",                                                                                                               

              "$clusterTime" : {                                                                                                                     

                      "clusterTime" : Timestamp(1634110955, 1),                                                                                      

                      "signature" :

      {                                                                                                                                         "hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),                                                                                             "keyId" : NumberLong(0)                                                                                                                 }

                                                                                                                                   

              },                                                                                                                                     

              "operationTime" : Timestamp(1634110952, 1)                                                                                             

      }

       

      Rather the user should be asked to shard the collection using range if the shard key happens to be the timeField.

            Assignee:
            alice.li@mongodb.com Alice Li (Inactive)
            Reporter:
            rushan.chen@mongodb.com Rushan Chen
            Votes:
            0 Vote for this issue
            Watchers:
            5 Start watching this issue

              Created:
              Updated:
              Resolved:
              None
              None
              None
              None