Introduccion a MongoDB - Fundamentos de Bases de Datos NoSQL

Principiante | 50 min de lectura | 2024.12.29

Lo que Aprenderas en este Tutorial

✓ Configuracion de MongoDB
✓ Operaciones CRUD
✓ Operadores de consulta
✓ Indices
✓ Pipeline de agregacion

Step 1: Configuracion

# macOS
brew tap mongodb/brew
brew install mongodb-community
brew services start mongodb-community

# Conectar
mongosh

Step 2: Operaciones Basicas

// Seleccionar base de datos
use myapp

// Insertar documento
db.users.insertOne({
  name: "Juan Garcia",
  email: "juan@example.com",
  age: 30
})

db.users.insertMany([
  { name: "Maria Lopez", email: "maria@example.com", age: 25 },
  { name: "Carlos Rodriguez", email: "carlos@example.com", age: 35 }
])

Step 3: Consultas

// Obtener todos
db.users.find()

// Especificar condiciones
db.users.find({ age: { $gte: 30 } })

// Operadores
db.users.find({
  $and: [
    { age: { $gte: 25 } },
    { age: { $lte: 35 } }
  ]
})

// Proyeccion
db.users.find({}, { name: 1, email: 1, _id: 0 })

// Ordenar y limitar
db.users.find().sort({ age: -1 }).limit(10)

Step 4: Actualizar y Eliminar

// Actualizar
db.users.updateOne(
  { email: "juan@example.com" },
  { $set: { age: 31 } }
)

// Actualizar multiples
db.users.updateMany(
  { age: { $lt: 30 } },
  { $set: { status: "young" } }
)

// Eliminar
db.users.deleteOne({ email: "juan@example.com" })

Step 5: Indices

// Crear indice
db.users.createIndex({ email: 1 }, { unique: true })

// Indice compuesto
db.users.createIndex({ age: 1, name: 1 })

// Verificar indices
db.users.getIndexes()

Step 6: Pipeline de Agregacion

db.orders.aggregate([
  { $match: { status: "completed" } },
  { $group: {
      _id: "$userId",
      totalAmount: { $sum: "$amount" },
      count: { $sum: 1 }
  }},
  { $sort: { totalAmount: -1 } },
  { $limit: 10 }
])

Step 7: Integracion con Node.js

import { MongoClient } from 'mongodb';

const client = new MongoClient('mongodb://localhost:27017');
await client.connect();

const db = client.db('myapp');
const users = db.collection('users');

const result = await users.find({ age: { $gte: 30 } }).toArray();
console.log(result);

await client.close();

Resumen

MongoDB maneja documentos en formato JSON con esquemas flexibles. El pipeline de agregacion permite analisis complejos.

← Volver a la lista