Diferencia entre revisiones de «SQL»

Contenido eliminado Contenido añadido
J.delanoy (discusión · contribs.)
m Revertidos los cambios de 200.112.86.59 a la última edición de J.delanoy
Línea 1:
El '''Lenguaje de consulta estructurado''' (SQL [/esekuˈele/ en español, /ɛskjuːˈɛl / o /ˈsiːkwəl/, en inglés] '''S'''tructured '''Q'''uery '''L'''anguage) es un [[Lenguajes declarativos|lenguaje declarativo]] de acceso a [[base de datos|bases de datos]] relacionales que permite especificar diversos tipos de operaciones sobre las mismas. Una de sus características es el manejo del [[álgebra relacional|álgebra]] y el [[cálculo relacional]] permitiendo lanzar [[consulta]]s con el fin de recuperar -de una forma sencilla- [[información]] de interés de una base de datos, así como también hacer cambios sobre la misma. Es un [[lenguaje]] de cuarta generación (4GL).
 
== Orígenes y evolución ==
 
Los orígenes del SQL están ligados a los de las bases de datos relacionales. En [[1970]] [[Edgar Frank Codd|E. F. Codd]] propone el [[modelo relacional]] y asociado a este un sublenguaje de acceso a los [[datos]] basado en el cálculo de predicados. Basándose en estas ideas, los laboratorios de [[IBM]] definen el lenguaje [[SEQUEL]] (Structured English QUEry Language) que más tarde sería ampliamente implementado por el [[Sistemas Gestores de Bases de Datos|SGBD]] (Sistemas Gestores de Bases de Datos) experimental System R, desarrollado en [[1977]] también por IBM. Sin embargo, fue [[Oracle]] quien lo introdujo por primera vez en [[1979]] en un programa comercial.
 
El SEQUEL terminaría siendo el predecesor de SQL, siendo éste una versión evolucionada del primero. El SQL pasa a ser el lenguaje por excelencia de los diversos [[SGBD]] relacionales surgidos en los años siguientes y es por fin estandarizado en [[1986]] por el [[ANSI]], dando lugar a la primera versión [[estándar]] de este lenguaje, el "SQL-86" o "SQL1". Al año siguiente este estándar es también adoptado por la [[ISO]].
 
Sin embargo este primer estándar no cubre todas las necesidades de los desarrolladores e incluye funcionalidades de definición de almacenamiento que se consideraron suprimir. Así que en [[1992]] se lanza un nuevo estándar ampliado y revisado del SQL llamado "SQL-92" o "SQL2".
 
En la actualidad el SQL es el estándar ''de facto'' de la inmensa mayoría de los SGBD comerciales. Y, aunque la diversidad de añadidos particulares que incluyen las distintas implementaciones comerciales del lenguaje es amplia, el soporte al estándar SQL-92 es general y muy amplio.
 
El ANSI SQL sufrió varias revisiones y agregados a lo largo del tiempo:
 
{| class=prettytable
! Año !! Nombre !! Alias !! Comentarios
|- valign=top
| [[1986]] || [[SQL-87|SQL-86]] || SQL-87 || Primera publicación hecha por ANSI. Confirmada por [[International Organization for Standardization|ISO]] en [[1987]].
|- valign=top
| [[1989]] || [[SQL-89]] || || Revisión menor.
|- valign=top
| [[1992]] || [[SQL-92]] || SQL2 || Revisión mayor.
|- valign=top
| [[1999]] || [[SQL1999|SQL:1999]] || SQL2000 || Se agregaron expresiones regulares, consultas recursivas (para relaciones jerárquicas), triggers y algunas características orientadas a objetos.
|- valign=top
| [[2003]] || [[SQL2003|SQL:2003]] ||  || Introduce algunas características de [[XML]], cambios en las funciones, estandarización del objeto sequence y de las columnas autonumericas. (Ver [http://www.acm.org/sigmod/record/issues/0403/index.html#standards Eisenberg et al.: ''SQL:2003 Has Been Published''].)
|- valign=top
| [[2006]] || [[SQL2006|SQL:2006]] ||  || ISO/IEC 9075-14:2006 Define las maneras en las cuales el SQL se puede utilizar conjuntamente con XML. Define maneras importar y guardar datos XML en una base de datos SQL, manipulándolos dentro de la base de datos y publicando el XML y los datos SQL convencionales en forma XML. Además, proporciona facilidades que permiten a las aplicaciones integrar dentro de su código SQL el uso de XQuery, lenguaje de consulta XML publicado por el W3C (World Wide Web Consortium) para acceso concurrente a datos ordinarios SQL y documentos XML.
|}
 
== Características generales ==