bases de datos

LIKE en MongoDB: consulta equivalente de SQL

Introducción

En SQL, nosotros podemos utilizar el operador LIKE para buscar coincidencias en donde la celda tenga una porción de una cadena. En este post voy a explicar cómo hacer un like en MongoDB, es decir, el equivalente a la cláusula LIKE de SQL pero aplicada a MongoDB.

Por ejemplo, suponiendo que hay una tabla de clientes así:

Y queremos consultar a aquellos cuyo nombre contenga la cadena “ra” haríamos una consulta así:

SELECT * FROM clientes WHERE nombre LIKE "%ra%";

Lo que devolvería algo como:

Ahora veamos cómo hacer eso con MongoDB.

Operador LIKE en MongoDB

Respuesta corta

La consulta quedaría así:

db.tu_coleccion.find({"campo": /.*busqueda.*/});

Y si quieres que ignore si son mayúsculas o minúsculas, así:

db.tu_coleccion.find({"campo": /.*busqueda.*/i});

Ejemplo

Muy fácil, suponiendo que tenemos una colección (de clientes) así:

Colección de clientes en MongoDB

Podemos buscar, de nuevo, aquellos que tenga “ra” con la siguiente consulta:

db.clientes.find({
    "Nombre": /.*ra.*/  }
);

Con estos resultados:

Resultados de consulta LIKE en MongoDB

Si queremos que sea insensitivo a mayúsculas (que devuelva aquellos en donde diga ra, Ra, rA o RA) entonces modificaríamos la consulta así:

db.clientes.find({
    "Nombre": /.*ra.*/i
  }
);

Básicamente es una expresión regular de JavaScript 😉

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Ver comentarios

  • Que pasaría en la consulta del tipo SELECT * FROM clientes WHERE nombre LIKE "%ra% OR WHERE apellido LIKE "%ra%"; Te agradezco. Saludos.

Entradas recientes

Resetear GOOJPRT PT-210 MTP-II (Impresora térmica)

El día de hoy vamos a ver cómo restablecer la impresora térmica GOOJPRT PT-210 a…

7 días hace

Proxy Android para impresora térmica ESC POS

Hoy voy a enseñarte cómo imprimir en una impresora térmica conectada por USB a una…

7 días hace

Android – Servidor web con servicio en segundo plano

En este post voy a enseñarte a programar un servidor web en Android asegurándonos de…

7 días hace

Cancelar trabajo de impresión con C++

En este post te quiero compartir un código de C++ para listar y cancelar trabajos…

1 mes hace

Copiar bytes de Golang a JavaScript con WebAssembly

Gracias a WebAssembly podemos ejecutar código de otros lenguajes de programación desde el navegador web…

2 meses hace

Imprimir PDF con Ghostscript en Windows de manera programada

Revisando y buscando maneras de imprimir un PDF desde la línea de comandos me encontré…

2 meses hace