MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

Bagaimana Anda mengubah string heksadesimal menjadi angka di mongodb?

Fungsi tersebut belum ada, lihat Mendukung konversi basis di $convert

Anda dapat mendefinisikan fungsi seperti ini:

function decimalToBase(input, base) {
   // works up to 72057594037927928 / FFFFFFFFFFFFF8
   var field = "$" + input;
   return {
      $let: {
         vars: {
            bits: {
               $reduce: {
                  input: { $range: [0, 56] },
                  initialValue: [{ dec: field }],
                  in: {
                     $cond: {
                        if: { $gt: [{ $last: "$$value.dec" }, 0] },
                        then: {
                           $concatArrays: ["$$value",
                              [{
                                 b: { $substrBytes: ["0123456789ABCDEF", { $mod: [{ $last: "$$value.dec" }, base] }, 1] },
                                 dec: { $trunc: { $divide: [{ $last: "$$value.dec" }, base] } }
                              }]
                           ]
                        },
                        else: "$$value"
                     }
                  }
               }
            }
         },
         in: {
            $reduce: {
               input: { $reverseArray: "$$bits.b" },
               initialValue: "",
               in: { $concat: ["$$value", "$$this"] }
            }
         }
      }
   }
};

function baseToDecimal(input, base) {
   // works up to 72057594037927928 / FFFFFFFFFFFFF8
   var field = "$" + input;
   return {
      $sum: {
         $map: {
            input: { $range: [0, { $strLenBytes: field }] },
            in: {
               $multiply: [
                  { $pow: [base, { $subtract: [{ $strLenBytes: field }, { $add: ["$$this", 1] }] }] },
                  { $indexOfBytes: ["0123456789ABCDEF", { $toUpper: { $substrBytes: [field, "$$this", 1] } }] }
               ]
            }
         }
      }
   };
}

lalu gunakan, misalnya seperti ini:

db.collection.insertOne({ hex: "A3F" })
db.collection.aggregate({ $set: { decimal: baseToDecimal("hex", 16)} })


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. kebingungan pelingkupan javascript node.js mongodb

  2. Bidang tambahan ke koleksi yang ada

  3. Elemen array pembaruan dokumen MongoDB menggunakan metode findOneAndUpdate di Java

  4. Cara membatasi jumlah pembaruan dokumen di mongodb

  5. Apa cara yang benar untuk Mengindeks di MongoDB ketika ada kombinasi besar bidang?