NoSql (Not only SQL) es un conjunto de bases de datos que tienen un propósito específico. Lo que significa que cada motor de base de datos soluciona un problema en especial. Por ejemplo:
MongoDB
resuelve un problema de escalabilidad.Redis
nos resuelve el problema de guardar información con llave - valor.
Las bases de datos relacionales no fueron diseñadas para hacer frente a los desafíos de escala y agilidad que enfrentan las aplicaciones modernas, ni tampoco fueron construidas para aprovechar el poder de almacenamiento y procesamiento de productos disponibles en la actualidad.
Full page cache
guardar todo el html de la pagina en bd.Query caching
almacenar el resultado de una consulta en bd.- Lectura y escritura con baja latencia.
Escalabilidad
Es la forma en la que la base de datos se expande a la hora de almacenar información, las bases de datos NoSQL están diseñadas para escalar fácilmente de manera horizontal, generando beneficios como alta disponibilidad.Esquemas de bases de datos flexibles
Podrías guardar diferentes tipos de información bajo la misma tabla, diferentes registros con diferentes campos en la misma colección.Velocidad
Las bases de datos pueden ser muy rápidas con respecto a las bases de datos SQL, un error común es tratar de que una base de datos NoSQL funcione como una base de datos relacional, mientras uses el motor de bases de datos para su propósito inicial vas a obtener las mejores características del motor.
No son transaccionales
Las transacciones son consultas generalmente de escritura, donde si ocurre un error, se hace rollback a todo lo que se hizo en la base de datos. NoSQL no garantiza que eso suceda, es desventaja si tu aplicación requiere que la información se guarde completa y se requiere volver a estados anteriores.No tiene joins
Porque de hecho no tiene relaciones. Con MongoDB muchas personas tratan de simular relaciones con los índices pero en ese punto Mongo pierde sentido, si estás usando una base de datos NoSQL debes evitar usar joins.
-
SQL es el lenguaje de programación que utilizan la mayoría de los sistemas, está basado en álgebra relacional. En una base de datos NoSQL no estamos obligados, incluso muchas veces el motor no implementa el lenguaje.
-
Las bases de datos NoSQL están diseñadas para ser distribuidas desde el comienzo, las bases de datos relacionales no.
-
Sharding: Con las bases de datos NoSQL puedo tener varios servidores y en cada servidor tener una parte de la base de datos, puedo distribuir la información y eso me facilita los procesos de recuperación y puedo escalar únicamente lo que necesito y no es necesario escalar todo el cluster. En las bases de datos relacionales es complejo el proceso de distribución.
¿Qué es MongoDB?
- Es una base de datos no relacional que nació en el 2007. Está programada en c++.
- Es una base de datos documental, significa que se almacena la información en documentos, es decir en formato json, se almacena en bson que son json pero binarios.
SQL
: MongoDB
database
: database
tables
: collections
rows
: documents (BSON)
columns
: fields
show dbs
mostrar las base de datos.use [base de datos]
usar la base de datos. También se usa para crear una bd.show collections
ver colecciones de la bd.db.createCollection("curso")
crea la colección curso.load("script.js")
carga un archivo con código JavaScript para usarlo.db.cursos.count()
mostrar la cantidad de documentos de la colección cursosdocumento = {"id": "bitcoin"}
crea una variable documento.
db.curso.insert({JSON-Document})
inserta un documento en la colección cursodb.curso.insertOne({JSON-Document})
//inserta solo un documento en la colección cursodb.curso.insertMany([{JSON-Document}, {JSON-Document}, {...}])
inserta varios documentos en la colección curso
db.curso.find()
devuelve los primeros 20 documentos de la colección curso..limit(n)
devuelve los primeros n documentos.pretty()
devuelve los primeros 20 documentos de manera legible
db.curso.find({"clave": "valor", "clave2": "valor2"})
devuelve los primeros 20 documentos con ls clave:valor y la clave2:valor2. La coma significa Y.db.curso.find({$or: [{"clave": "valor" }, {"clave2": "valor2"}]})
devuelve los primeros 20 documentos con ls clave:valor o la clave2:valor2. Cada objeto del formato JSON representa un O.db.curso.find({"clave": {$gt: "valor"}})
devuelve según el filtro$gt
Significa mayor que (>).$lt
Significa menor que (<).$gte
Significa mayor o igual a (>=).$lte
Significa menor o igual a (<=).
db.curso.find({"clave": "valor"}, {"clave2": 0})
ocultar la clave2 de los resultados de la búsqueda.db.curso.findOne()
devuelve el primer elemento
db.curso.save({JSON-Document})
inserta o actualiza un documento.db.curso.update({filtro}, {JSON-Document})
actualiza el documento por completo. Elimina todos los campos y agrega los nuevos dejando solo el _id. El filtro es como en los filtros de find.db.curso.updateOne({filtro}, {JSON-Document})
actualiza el primer documento que encuentre.db.curso.updateMany({filtro}, {JSON-Document})
actualiza todos los documentos que coincidan con el filtro.
Para actualizar lo ideal es guardar en una variable el campo que quieres actualizar y luego aplicar SAVE o UPDATE.
db.curso.drop()
elimina todos los documentos de una colección incluyendo la colección.db.curso.remove({filtro})
elimina todos los documentos que cumplen con el filtro JSON.