Download NoSQL vs SQL – ¿Tiempo para un Cambio?
Document related concepts
Transcript
2015 Herramientas SQL vs NoSQL Peña Contreras Daniel Administración de Base de Datos 27/09/2015 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos MITO: NoSQL reemplaza SQL Eso sería como decir que los barcos fueron reemplazados por los coches porque son una tecnología más nueva. SQL y NoSQL hacer lo mismo: almacenar datos. Ellos toman diferentes enfoques, que pueden ayudar u obstaculizar su proyecto. A pesar de sentirse más reciente y el acaparamiento de los titulares recientes, NoSQL no es un reemplazo para SQL - es una alternativa. MITO: NoSQL es mejor / peor que SQL Algunos proyectos se adaptan mejor a la utilización de una base de datos SQL. Algunos son más adecuados para NoSQL. Algunos pueden utilizar indistintamente. Este artículo nunca podría ser un SitePoint Smackdown, porque no se puede aplicar las mismas suposiciones generales en todas partes. MITO: SQL vs NoSQL es una clara distinción Esto no es necesariamente cierto. Algunas bases de datos SQL están adoptando características NoSQL y viceversa. Las opciones pueden llegar a ser cada vez más difusa, y las bases de datos híbridos NewSQL podrían proporcionar algunas opciones interesantes en el futuro. MITO: el lenguaje / marcó determina la base de datos Hemos crecido acostumbrar a pilas de tecnología, tales como LAMP: Linux, Apache, MySQL (SQL), PHP Decir: MongoDB (NoSQL), Express, angulares, Node.js .NET, IIS y SQL Server Java, Apache y Oracle. Hay razones prácticas, históricas y comerciales por qué estas pilas evolucionaron - pero no presumen que son reglas. Puede usar una base de datos MongoDB NoSQL en tu PHP o .NET proyecto. Puede conectarse a MySQL o SQL Server en Node.js. Usted no puede encontrar la mayor cantidad de tutoriales y recursos, pero sus necesidades debe determinar el tipo de base de datos - no el lenguaje. 2 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos SQL El lenguaje de consulta estructurado o SQL (por sus siglas en inglés Structured Query Language) es un lenguaje declarativo de acceso a bases de datos relacionales que permite especificar diversos tipos de operaciones en ellas. Una de sus características es el manejo del álgebra y el cálculo relacional que permiten efectuar consultas con el fin de recuperar, de forma sencilla, información de bases de datos, así como hacer cambios en ellas. NoSQL En informática, NoSQL es una amplia clase de sistemas de gestión de bases de datos que difieren del modelo clásico del sistema de gestión de bases de datos relacionales (RDBMS) en aspectos importantes, el más destacado es que no usan SQL como el principal lenguaje de consultas. Los datos almacenados no requieren estructuras fijas como tablas, normalmente no soportan operaciones JOIN, ni garantizan completamente ACID (atomicidad, consistencia, aislamiento y durabilidad), y habitualmente escalan bien horizontalmente. Los sistemas NoSQL se denominan a veces "no sólo SQL" para subrayar el hecho de que también pueden soportar lenguajes de consulta de tipo SQL. ¿Cuál es el mejor? Antes de la aparición del concepto de Base de datos relacional en el año de 1970, se utilizaban técnicas de manipulación de ficheros para guardar y gestionar la información que generaba una aplicación, trayendo consigo la necesidad de comprender a cabalidad temas como el acceso a memoria, el manejo de punteros y puertos, etc. (¡Que caos!). Con la aparición de conceptos como tablas, relaciones, claves y la unificación de los términos fila y dato toda ésta engorrosa tarea se convirtió en más que un objeto de estudio y trajo alegrías y colores a muchos programadores de la época. Salir de esa zona de confort, implica – implícitamente – la necesidad de expresar esos miedos a temas tan oscuros en la programación y la preocupación de complicar más la profesión del desarrollo y la gestión de datos. NoSQL facilita demasiado la gestión de la información en ciertos aspectos como la captura o el soporte de escalabilidad y acceso; facilita tanto la tarea, que en un futuro cercano estoy seguro que no nos preocuparemos si quiera de proporcionar una cadena de conexión como las engorrosas de SQL Server, 3 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos sólo tendríamos que proporcionar un nombre y el mismo motor de base de datos realizará todo ese tedioso y aburrido procedimiento. Por lo anterior, no podemos temerle a la maravillosa tecnología del NoSQL y su gran utilidad en el nuevo mundo de la Internet – ni tan nuevo, de hecho -, porque se están solucionando grandes inconvenientes como la masiva concurrencia de acceso a una base de datos y el costoso mantenimiento de las mismas. Hay que aceptar de una vez por todas que NoSQL vino para quedarse y más importante, vino para facilitarnos la vida y quitarnos más de un dolor de cabeza para empresarios y desarrolladores. ¿Cuándo usar SQL? Si buscamos en Google no encontraremos una respuesta concreta, porque se intuye que cualquier cosa que se deba guardar debe ser en una base de datos relacional. Si preguntamos a cualquier programador, seguramente su respuesta sería algo como: “en prácticamente cualquier caso. De pronto no es necesario en desarrollos de animación o cosas por el estilo.”. Yo considero que una base de datos relacional puede ser usada estos ámbitos: Educativo: es importante conocer cómo estructurar información, además de aportar un gran conocimiento lógico al estudiante. Desarrollo web: es bueno tratar de mantener una misma jerarquía de los datos que llegan de la gran autopista, pero siempre y cuando la capacidad de concurrencia, almacenamiento y mantenimiento no sean de considerable dificultad y la información siempre sea consistente. Rama de negocios: inteligencia de negocios, análisis de negocios, bodegas de datos, minería de datos, minería de texto son temas que requieren el uso de SQL para facilitar el consumo de la información y la identificación de patrones en los datos. Empresarial: El software a la medida y el software empresarial, ambos de escritorio, poseen la característica de mantener información con una estructura consistente y SQL es ideal para ésta tarea. 4 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos ¿Cuándo usar NoSQL? Si realizamos el ejercicio en Google, encontramos un poco más de información al respecto y es más sencillo orientarse en ésta nueva tecnología. Yo considero que las tecnologías NoSQL pueden user usadas en los siguientes ámbitos: Redes sociales: Es obligatorio. Gracias a las redes sociales, ésta tecnología comenzó a despegar y mostrar utilidad en el campo de la informática y la estadística. Desarrollo Web: Considero más pertinente el uso de éstas tecnologías en ésta área, debido a la poca uniformidad de la información que encontramos en Internet, sin embargo, es posible realizar éstos desarrollos con SQL, como expuse anteriormente. Desarrollo Móvil: En éstos momentos, las empresas están lidiando con un problema grande conocido como Bring Your Own Device – en realidad no es un problema, es un fenómeno social -, por lo que la información que se recolecte siempre será diferente por más que uno desee estructurarla y mantenerla estática. BigData: Como podemos observar en Search Business Analytics, la administración de grandísimas cantidades de información y su evidente heterogeneida hace de NoSQL un excelente candidato en ésta área. Cloud (XaaS): el término XaaS (Everything as a service) que indica “Cualquier cosa como servicio (sic)” y todos los temas relacionados a la nube, con NoSQL pueden adaptarse casi a cualquier necesidad del cliente, que evidentemente son heterogéneos. Beneficios de NoSQL Escalamiento elástico Mayor capacidad de manejo de datos El mantenimiento de los servidores NoSQL es más barato Menor Costo Servidor No esquema o modelo de datos fijos Integrated Facility Caching 5 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos Beneficios de SQL Es un estándar para el manejo de datos en un Manejador de Base de Datos Relacional. Es no sensitivo, esto quiere decir que no importa si pones en mayúsculas o minúsculas el comando o instrucción te lo reconocerá. Es imperativo, no necesariamente secuencial aunque tenga un ordenamiento. Es de fácil comprensión. Es un lenguaje de alto nivel para datos, esto es con una sola instrucción afectas a varios registros en tiempo real. Diferencia entre SQL y NoSQL: Comparación Este artículo sobre SQL y NoSQL comparación arrojará luz sobre el debate sobre las ventajas y limitaciones de cada uno. Desde que el zumbido de la base de datos NoSQL evolucionó en el almacenamiento de datos en las bases de datos NoSQL, pensé en la exploración de ambos conceptos para llegar a su profundidad. Y me tomó un tiempo para averiguar lo que realmente conducen a la evolución de la base de datos NoSQL. Bueno, todo se reduce a la búsqueda de proporcionar mejor experiencia posible a los usuarios finales en forma rápida, real y conectado. Los desarrolladores de bases de datos están tratando de optimizar las cosas para producir un mejor rendimiento ya que la tecnología en el departamento de almacenamiento está cambiando drásticamente. NoSQL vs SQL – ¿Tiempo para un Cambio? SQL (Structured Query Language) fue creado en la década de 1970 para dar a las bases de datos relacionales una manera de almacenar datos y comunicarse, y es muy popular en todo el mundo. NoSQL, en contraste, se refiere a un nuevo tipo de bases de datos no relacionales que no utilizan SQL y están ganando popularidad. Obtener una sólida. 6 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos Existe un intenso debate entre los desarrolladores en cuanto a los méritos de cada sistema, incluso en Google I/O 2012, se realizó un debate titulado SQL vs NoSQL: Batalla de los Backends. Cada uno tiene sus propias fortalezas y debilidades, pero algunos predicen que NoSQL puede eventualmente reemplazar a SQL. Así que, ¿cuáles son esas diferencias? Echemos un vistazo a algunas de las características clave de NoSQL y cómo se diferencia de SQL. ¿Por qué podría NoSQL funcionar mejor que SQL? Hay varias razones para creer que las bases de datos no relacionales son más adecuadas para la actualidad que las bases de datos relacionales. Las relaciones y las tablas que conforman las bases de datos SQL pueden funcionar para las grandes organizaciones, que cuentan con millones. Combine esto con millones de usuarios que realizan búsquedas en estas tablas y el sistema puede sufrir grandes problemas de rendimiento, como descubrieron Google y Amazon de la manera más dura antes de cambiar a sistemas no relacionales. Además, los proyectos de programación a gran escala que utilizan tipos de datos complejos y jerarquías, como XML, son difíciles de incorporar en SQL. Estos tipos de datos, que pueden contener objetos, listas y otros tipos de datos propios, no se correlacionan bien con las tablas que consisten en sólo las filas y columnas. Por otro lado, los proyectos y las organizaciones más pequeñas normalmente funcionan muy bien con SQL. Si bien puede ser difícil en algunos casos, el mapeo de objetos complejos utilizando tablas se puede hacer y hay poderosas herramientas disponibles, tales como el sistema de base de datos Oracle, que son muy eficaces. Los sistemas SQL y NoSQL pueden ambos funcionar bien cuando son manejados por administradores competentes, pero la mejor opción dependerá de cómo se va a utilizar y las habilidades de las personas que van a utilizarlas. Con esto en mente, echemos un vistazo a algunas características de NoSQL, diseñadas para evitar algunos de los inconvenientes de SQL. 7 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos Bases de Datos NoSQL: Tipos de datos y funciones La mayoría de las bases de datos NoSQL contienen los cuatro tipos de datos siguientes: Bases de datos documentales, que permiten que una clave sea emparejada con un documento. Los documentos pueden contener una gran variedad de objetos como claves en arreglos y pares clavevalor, así como otros documentos. Key-value stores, bases de datos simples que almacenan información en forma de atributos (teclas) y valores. En algunos casos, los valores pueden tener tipos como cadena y número entero. El graph almacena datos sobre redes. Wide-column stores, están hechas para el manejo de grandes cantidades de datos en forma de columnas. Las bases de datos NoSQL escalan horizontalmente, añadiendo más servidores para hacer frente a cargas más grandes. Por otro lado, las bases de datos SQL, suelen escalar de forma vertical, añadiendo más y más tráfico a un solo servidor. La función Auto-sharding permite a los sistemas NoSQL compartir automáticamente los datos a través de servidores, sin necesidad de realizar algunas maniobras complejas de codificación. Esto equilibra la carga entre varios servidores, proporcionando un sistema más robusto en caso de un accidente de un servidor en particular. La programación de hoy en día se hace a menudo de forma iterativa, con pequeños pasos, poco a poco que puede afectar a todo el proyecto. Esto no se traduce bien a los servidores SQL, que le piden que defina sus esquemas antes de agregar cualquier información. Añadir una nueva categoría a una tabla, por ejemplo, puede llegar a ser un proceso que consuma tiempo cuando se haga tarde en un proyecto de programación. NoSQL es mucho más flexible, no utilizando esquemas definidos de antemano. Esto permite a los usuarios añadir información y hacer cambios en cualquier momento sin interrumpir el sistema o la necesidad de transferir una gran cantidad de datos. Una comparación de SQL y No-SQL Base de datos Sistemas de Gestión Con el fin de llegar a una conclusión comprensible simple, vamos a analizar las diferencias de los sistemas de gestión de SQL y No-SQL de base de datos': 8 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos Estructura y tipo de datos que se mantienen: SQL / bases de datos relacionales requieren de una estructura con los atributos definidos para contener los datos, a diferencia de las bases de datos NoSQL que por lo general permiten las operaciones de flujo libre. Consulta: Independientemente de sus licencias, bases de datos relacionales todos implementan el estándar SQL, hasta cierto punto y, por tanto, que se pueden consultar mediante el Structured Query Language (SQL).Bases de datos NoSQL, por el contrario, cada implementar una forma única de trabajar con los datos que manejan. Escala: Ambas soluciones son fáciles de escalar verticalmente (es decir, mediante el aumento de los recursos del sistema). Sin embargo, siendo las aplicaciones más modernas (y más simples), soluciones NoSQL suelen ofrecer medios mucho más fácil a escala horizontal (es decir, mediante la creación de un grupo de varias máquinas). Fiabilidad: Cuando se trata de fiabilidad de los datos y la garantía de seguridad de las transacciones realizadas, las bases de datos de SQL siguen siendo la mejor apuesta. Soporte: Sistemas de gestión de bases de datos relacionales tienen décadas de historia. Son muy populares y es muy fácil de encontrar tanto gratuitos y pagados apoyo. Si surge un problema, por lo que es mucho más fácil de resolver que las bases de datos recientemente populares NoSQL especialmente si dicha solución es compleja en la naturaleza (por ejemplo, MongoDB). Mantenimiento de datos complejos y las necesidades de consulta de: Por naturaleza, las bases de datos relacionales son el go-to solución para consultas complejas y los datos de mantenimiento de las necesidades. Ellos son mucho más eficientes y sobresalir en este dominio. 9 Peña Contreras Daniel Herramientas SQL vs No SQL Administración de Base de Datos https://estebanz01.wordpress.com/2013/04/04/sql-vs-nosql-cual-es-elmejor/ https://es.wikipedia.org/wiki/SQL https://es.wikipedia.org/wiki/NoSQL http://www.thewindowsclub.com/difference-sql-nosql-comparision https://blog.udemy.com/es/nosql-vs-sql-tiempo-para-un-cambio/ http://www.sitepoint.com/sql-vs-nosql-differences/ https://www.digitalocean.com/community/tutorials/understanding-sql-andnosql-databases-and-different-database-models 10