Movatterモバイル変換


[0]ホーム

URL:


Ir al contenido
WikipediaLa enciclopedia libre
Buscar

NoSQL

De Wikipedia, la enciclopedia libre
Este artículo o sección necesitareferencias que aparezcan en unapublicación acreditada.
Busca fuentes:«NoSQL»noticias ·libros ·académico ·imágenes
Este aviso fue puesto el 22 de septiembre de 2024.

Eninformática,NoSQL (a veces llamado "no solo SQL") es una amplia clase desistemas de gestión de bases de datos que difieren del modelo clásico deSGBDR (Sistema de Gestión deBases de Datos Relacionales) en aspectos importantes, siendo el más destacado que no usanSQL comolenguaje principal de consultas.[1]​ Los datos almacenados no requieren estructuras fijas comotablas, normalmente no soportan operacionesJOIN, ni garantizan completamenteACID (atomicidad, consistencia, aislamiento y durabilidad) y habitualmente escalan bienhorizontalmente.[2]​ Los sistemas NoSQL se denominan a veces "no solo SQL" para subrayar el hecho de que también pueden soportar lenguajes de consulta de tipo SQL.

Por lo general, los investigadores académicos se refieren a este tipo debases de datos comoalmacenamiento estructurado, término que abarca también las bases de datos relacionales clásicas. A menudo, las bases de datos NoSQL se clasifican según su forma de almacenar los datos, y comprenden categorías comoclave-valor, las implementaciones deBigTable, bases de datos documentales, ybases de datos orientadas a grafos.[3]

Los sistemas de bases de datos NoSQL crecieron con las principales redes sociales, como Google, Amazon, Twitter y Facebook.[4]​ Estas tenían que enfrentarse a desafíos con el tratamiento de datos que las tradicionales SGBDR no solucionaban. Con el crecimiento de la web en tiempo real existía una necesidad de proporcionar información procesada a partir de grandes volúmenes de datos que tenían unas estructuras horizontales más o menos similares. Estas compañías se dieron cuenta de que el rendimiento y sus propiedades de tiempo real eran más importantes que la coherencia, en la que las bases de datos relacionales tradicionales dedicaban una gran cantidad de tiempo de proceso[cita requerida].

En ese sentido, a menudo, las bases de datos NoSQL están altamente optimizadas para las operaciones recuperar y agregar, y normalmente no ofrecen mucho más que la funcionalidad de almacenar los registros (p.ej.almacenamiento clave-valor). La pérdida de flexibilidad en tiempo de ejecución, comparado con los sistemas SQL clásicos, se ve compensada por ganancias significativas en escalabilidad y rendimiento cuando se trata con ciertos modelos de datos.[cita requerida]

Historia del término

[editar]

Carlo Strozzi usó el término NoSQL en 1998 para referirse a su base de datos. Era una base de datos open-source, ligera, que no ofrecía una interfaz SQL, pero sí seguía el modelo relacional[5]​ (Strozzi sugiere que, ya que el actual movimiento NoSQL "Se sale completamente del modelo relacional, debería, por tanto, haberse llamado 'NoREL', o algo así.").[6]

Eric Evans, un empleado deRackspace, reintrodujo el término NoSQL cuando Johan Oskarsson deLast.fm quiso organizar un evento para discutir bases de datos distribuidas de código abierto. El nombre intentaba recoger el número creciente de bases de datos no relacionales y distribuidas que no garantizabanACID, atributo clave en las SGBDR clásicas.[cita requerida]

Arquitectura

[editar]

Típicamente las bases de datos relacionales modernas han mostrado poca eficiencia en determinadas aplicaciones que usan los datos de forma intensiva, incluyendo el indexado de un gran número de documentos, la presentación de páginas en sitios que tienen gran tráfico, y en sitios de streaming audiovisual. Las implementaciones típicas de SGBDR se han afinado o bien para una cantidad pequeña pero frecuente de lecturas y escrituras o para un gran conjunto de transacciones que tiene pocos accesos de escritura. Por otro lado NoSQL puede servir gran cantidad de carga de lecturas y escrituras.

Implementaciones de NoSQL usadas en el mundo real incluyen los 3TB de los marcadores verdes deDigg (indicados para señalar las historias votadas por otros en la red social; aunque duró menos de 3 meses y fue abandonado); los 6 TB de la base de datos del “ENSEMBLE” de laComisión Europea usado en los modelos de comparación y calidad del aire, y los 50 TB de la búsqueda de la bandeja de entrada de wasa.

Las arquitecturas NoSQL frecuentemente aportan escasas garantías de consistencia, tales como consistencia de eventos o transaccional restringida a ítems únicos de datos. Algunos sistemas, sin embargo, aportan todas las garantías de los sistemas ACID en algunas instancias añadiendo una capa intermedia (como por ejemplo, AppScale o CloudTPS). Hay dos sistemas que han sido desplegados y que aportan aislamiento snapshot para almacenamientos de columna: El sistema Percolator de Google (basado en el sistema BigTable) y el sistema transaccional de Hbase desarrollado por la Universidad de Waterloo. Estos sistemas, desarrollados de forma independiente, usan conceptos similares para conseguir transacciones ACID distribuidas de múltiples filas con garantías de aislamiento snapshot para el sistema subyacente de almacenamiento en esa columna, sin sobrecarga extra en la gestión de los datos, despliegue en el sistema de middleware, ni mantenimiento introducido por la capa de middleware.

Bastantes sistemas NoSQL emplean una arquitectura distribuida, manteniendo los datos de forma redundante en varios servidores, usando frecuentemente una tabla hash distribuida. De esta forma, el sistema puede realmente escalar añadiendo más servidores, y el fallo en un servidor puede ser tolerado.

Algunos defensores de NoSQL promueven interfaces simples tales como los arrays asociativos o los pares clave-valor. Otros sistemas, tales como las bases de datos nativas en XML, promueven el soporte del estándar Xquery. Los sistemas más novedosos tales como CloudTPS también soportan unión de queries.

Ventajas

[editar]
  • Estos sistemas responden a las necesidades de escalabilidad horizontal que tienen cada vez más empresas.[7]
  • Pueden manejar enormes cantidades de datos.
  • No generan cuellos de botella.
  • Escalamiento sencillo.
  • Diferentes DBs NoSQL para diferentes proyectos.
  • Se ejecutan en clusters de máquinas baratas.

Desventajas

[editar]
Existen desacuerdos sobre laneutralidad en el punto de vista de la versión actual de este artículo o sección.
Enla página de discusión puedes consultar el debate al respecto.
  • Las bases de datos NoSQL al ser de código abierto poseen un soporte diferente al soporte que ofrecen las compañías comerciales a sus productos. Esto puede presentar algunas ventajas y también algunas desventajas.
  • Algunos productos pueden no estar lo suficientemente maduros para algunas empresas.- A pesar de sus puestas en práctica en algunas grandes empresas, las bases de datos NoSQL aún se enfrentan a un problema de credibilidad importante con muchas empresas. Los críticos señalan la falta de madurez de NoSQL y los posibles problemas de inestabilidad, mientras que citan la madurez, y una gran funcionalidad y estabilidad de los SGBDRes. No obstante, en desarrollos de sistemas, al disponer del código fuente, este se puede ajustar y amoldar a las necesidades concretas de cada empresa.
  • Limitaciones de Inteligencia de Negocios.- Hay una o dos cuestiones acerca de las capacidades de BI de las bases de datos NoSQL. ¿Pueden estas bases de datos proporcionar la clase deminería de datos rigurosos que las empresas se utilizan con las SGBDRes? ¿Cuántos conocimientos de programación se necesitan para hacer la consulta ad hoc y análisis?. Las respuestas no son precisamente positivas. Las bases de datos NoSQL no tienen muchos ganchos para el uso general de herramientas de BI, mientras que la más simple consultaad hoc y análisis implica conocimientos de programación bastante buenos. Sin embargo, las soluciones están disponibles. Quest Software, por ejemplo, ha creado Toad para bases de datos en la nube, que proporciona capacidades de consultaad hoc para algunas bases de datos NoSQL.
  • La falta de experiencia.- La novedad de NoSQL significa que no hay una gran cantidad de desarrolladores y administradores que conocen la tecnología -lo que hace difícil a las empresas encontrar personas con los conocimientos técnicos apropiados. Por el contrario, el mundo SGBDR tiene miles de personas muy cualificadas.
  • Problemas de compatibilidad.- A diferencia de las bases de datos relacionales, que comparten ciertos estándares, las bases de datos NoSQL tienen pocas normas en común. Cada base de datos NoSQL tiene su propia API, las interfaces de consultas son únicas y tienen peculiaridades. Esta falta de normas significa que es imposible cambiar simplemente de un proveedor a otro, por si no quedara satisfecho con el servicio.

Sistemas

[editar]
La redacción de este artículo o sección debería adecuarse a lasconvenciones de estilo de Wikipedia.Puedes colaborareditándolo.
Cuando se haya corregido, por favor borra este aviso, pero no antes.Este aviso fue puesto el 22 de septiembre de 2024.

Tabla Comparativa de SGBD NoSQL

[editar]
NombreDescripción
CassandraBase de datos creada porFacebook y luego donada a laFundación Apache del tipo clave-valor. Dispone de un lenguaje propio para realizar consultas CQL (Cassandra Query Language). Cassandra es una aplicaciónJava por lo que puede correr en cualquier plataforma que cuente con laJVM. Esmultiplataforma.
RedisBase de datos creada por Salvatore Sanfilippo y Pieter Noordhuis y está apoyado porVMWare. Se trata de una base de datos del tipo clave-valor. Se puede imaginar como un array gigante en memoria para almacenar datos, datos que pueden ser cadenas, hashes, conjuntos de datos o listas. Tiene la ventaja de que sus operaciones son atómicas y persistentes. Sin embargo, Redis no permite realizar consultas, solo se puede insertar y obtener datos, además de las operaciones comunes sobre conjuntos (diferencia, unión e inserción). Creado enANSI C, por lo tanto, es compatible y funciona sin problemas en sistemasUnix,Linux y sus derivados,Solaris,OS/X, sin embargo no existe soporte oficial para plataformasWindows.
MongoDBBase de datos creada por MongoDB Inc. (anteriormente 10gen) del tipo orientada a documentos, de esquema libre, es decir, que cada entrada puede tener un esquema de datos diferente que nada tenga que ver con el resto de registros almacenados. Es bastante rápido a la hora de ejecutar sus operaciones ya que maneja datos binarios. En poco tiempo, MongoDB se ha convertido en una de las bases de datos NoSQL favoritas por los desarrolladores. Está escrito en lenguajeC++. Para el almacenamiento de la información, utiliza un sistema propio de documento conocido con el nombreBSON, que es una evolución del formatoJSON pero con la peculiaridad de que puede almacenar datos representados de forma binaria. Está disponible para los sistemas operativosWindows,Linux,OS/X ySolaris.
CouchDBSistema creado porApache y escrito en el lenguajeErlang que funciona en la mayoría de sistemas POSIX (multiplataforma), incluyendoGNU/Linux yOS/X, además de sistemasWindows. Como características más importantes cabe destacar el uso deRESTful HTTP API como interfaz yJavaScript como principal lenguaje de interacción. Para el almacenamiento de los datos se utilizan archivosJSON. Permite la creación de vistas, que son el mecanismo que permite la combinación de documentos para retornar valores de varios documentos, es decir, CouchDB permite la realización de las operaciones JOIN típicas deSQL.

Bases de datos documentales

[editar]
Artículo principal: Base de datos documental
  • CouchDB, de Apache CouchD
  • MongoDB, de MongoDB Inc.
  • RavenDB, de Hibernating Rhinos
  • BaseX
  • djondb
  • eXist
  • SimpleDB, deAmazon
  • IBM Lotus Domino
  • Terrastore

Bases de datos en grafo

[editar]
Artículo principal: Base de datos orientada a grafos
  • Neo4j
  • DEX/Sparksee
  • AllegroGraph
  • OrientDB
  • InfiniteGraph
  • Sones GraphDB
  • InfoGri
  • HyperGraphDB

Bases de datos clave/valor

[editar]
Artículo principal: Base de datos clave-valor

Bases de datos multivalor

[editar]
Artículo principal: Base de datos multivalor
  • Rocket D3 DBMS
  • Rocket mvBase DBMS
  • Rocket U2 Universe
  • Rocket U2 Unidata
  • OpenQM
  • Caché InterSystems
  • Reality
  • Jbase
  • OpenInsight
  • Extensible storage engine

Bases de datos orientadas a objetos

[editar]
Artículo principal: Base de datos orientada a objetos

Bases de datos tabular

[editar]

Bases de datos de arrays

[editar]
  • SciDB, de Paradigm4

Referencias

[editar]
  1. IBM (ed.).«¿Qué es una base de datos NoSQL?». Consultado el 3 de noviembre de 2025. 
  2. Amazon Web Services (ed.).«¿Qué son las bases de datos NoSQL?». Consultado el 3 de noviembre de 2025. 
  3. MongoDB, Inc. (ed.).«What is NoSQL?»(en inglés). Consultado el 3 de noviembre de 2025. 
  4. Microsoft Azure Architecture Center (ed.).«Non-relational data and NoSQL»(en inglés). Consultado el 3 de noviembre de 2025. 
  5. Lith, Adam; Mattson, Jakob (2010).«Investigating storage solutions for large data: A comparison of well performing and scalable data storage solutions for real time extraction and batch insertion of data»(PDF). Göteborg: Department of Computer Science and Engineering, Chalmers University of Technology. p. 15. Consultado el 12 de mayo de 2011. «Carlo Strozzi first used the term NoSQL in 1998 as a name for his open source relational database that did not offer a SQL interface[...]». 
  6. «NoSQL Relational Database Management System: Home Page». Strozzi.it. 2 de octubre de 2007. Consultado el 29 de marzo de 2010. 
  7. Twitter planifica la migración de MySQL a Cassandra DBArchivado el 5 de marzo de 2010 enWayback Machine. en barrapunto

Enlaces externos

[editar]
Control de autoridades

Obtenido de «https://es.wikipedia.org/w/index.php?title=NoSQL&oldid=170297881»
Categoría:
Categorías ocultas:

[8]ページ先頭

©2009-2026 Movatter.jp