sql >> Database teknologi >  >> NoSQL >> MongoDB

Kort brugervenligt ID til mongo

Du forsøger at konvertere en base-16 (hexadecimal) til base-36 (26 tegn i alfabetet plus 10 tal). En simpel måde kan være at bruge parseInt 's radix-parameter for at parse det hexadecimale id og derefter kalde .toString(36) at konvertere det til base-36. Hvilket ville forvandle "507f191e810c19729de860ea" til "VDFGUZEA49X1V50356", hvilket reducerer længden fra 24 til 18 tegn.

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. Forbedre forespørgselsfelter findes i MongoDB

  2. Henvisning til andre dokumenter efter streng i stedet for ObjectId

  3. Forbindelsestimeout til MongoDb på Azure VM

  4. hvorfor brugen af ​​en ORM med NoSql (som MongoDB)