sql >> Database >  >> NoSQL >> MongoDB

Korte gebruiksvriendelijke ID voor mongo

U probeert een grondtal-16 (hexadecimaal) om te zetten naar grondtal 36 (26 tekens in alfabet plus 10 cijfers). Een eenvoudige manier zou kunnen zijn om gewoon parseInt . te gebruiken 's radix-parameter om de hexadecimale id te ontleden en roep vervolgens .toString(36) aan om dat om te zetten in base-36. Dat zou "507f191e810c19729de860ea" veranderen in "VDFGUZEA49X1V50356", waardoor de lengte zou worden teruggebracht van 24 naar 18 tekens.

function toBase36(id) {
  var half = Math.floor(id.length / 2);
  var first = id.slice(0, half);
  var second = id.slice(half);
  return parseInt(first, 16).toString(36).toUpperCase()
       + parseInt(second, 16).toString(36).toUpperCase();
}

function toBase36(id) {
  var half = Math.floor(id.length / 2);
  var first = id.slice(0, half);
  var second = id.slice(half);
  return parseInt(first, 16).toString(36).toUpperCase()
       + parseInt(second, 16).toString(36).toUpperCase();
}

// Ignore everything below (for demo only)
function convert(e){ if (e.target.value.length % 2 === 0) base36.value = toBase36(e.target.value) }
var base36 = document.getElementById('base36');
var hex = document.getElementById('hex');
document.getElementById('hex').addEventListener('input', convert, false);
convert({ target: { value: hex.value } });
input { font-family: monospace; width: 15em; }
<input id="hex" value="507f191e810c19729de860ea">
<input id="base36" readonly>


  1. kan mongodb lokale server niet starten

  2. Hoe importeer ik alleen niet bestaande documenten?

  3. Reg:mongo db verkeerde uitvoer volgens query

  4. Mongodb-aggregatie - sorteren maakt de zoekopdracht erg traag