Base de Datos 1 2023
Base de Datos 1 2023
Contenidos generales:
En este módulo aprenderás sobre bases de datos y cómo trabajar con ellas utilizando el
lenguaje SQL y MongoDB. Comenzaremos con una introducción a las bases de datos,
incluyendo los diferentes tipos de bases de datos y cómo acceder a ellas utilizando el entorno
MySQL. También aprenderás cómo crear una base de datos, hacer una copia de seguridad y
restaurarla.
Luego nos centraremos en el lenguaje SQL y sus sublenguajes. Aprenderás cómo manipular y
gestionar datos, y cómo crear consultas SQL para extraer información de las bases de datos.
Te enseñaremos la estructura básica de una consulta SQL y cómo utilizar las cláusulas
SELECT, FROM y WHERE para filtrar los datos. También explorarás JOINs y subconsultas,
así como las funciones de agregación y escalares.
En la sección de MongoDB, aprenderás qué es una base de datos NoSQL y cómo se
diferencia de las bases de datos relacionales. Veremos las características de MongoDB y
cómo utilizarla en la creación de aplicaciones.
¿Qué es MySQL?
MySQL, el sistema de administración de bases de datos SQL de código abierto más popular, está
desarrollado, distribuido y respaldado por Oracle Corporation.
Una base de datos es una colección estructurada de datos. Puede ser cualquier cosa, desde una simple
lista de compras hasta una galería de imágenes o la gran cantidad de información en una red
corporativa. Para agregar, acceder y procesar datos almacenados en una base de datos informática, se
necesita un sistema de administración de bases de datos como MySQL Server. Dado que las
computadoras son muy buenas para manejar grandes cantidades de datos, los sistemas de
administración de bases de datos juegan un papel central en los sistemas actuales, como utilidades
independientes o como parte de otras aplicaciones.
Las bases de datos MySQL son relacionales.
Una base de datos relacional almacena datos en tablas separadas en lugar de poner todos los datos en
un gran archivo. Las estructuras de la base de datos están organizadas en archivos físicos optimizados
para la velocidad. El modelo lógico, con objetos como bases de datos, tablas, vistas, filas y columnas,
ofrece un entorno de programación flexible.
Esto configura reglas que gobiernan las relaciones entre diferentes campos de datos, como uno a uno,
uno a muchos, único, obligatorio u opcional, y " punteros " entre diferentes tablas. La base de datos
hace cumplir estas reglas, de modo que con una base de datos bien diseñada, tu aplicación nunca ve
datos inconsistentes, duplicados, huérfanos, desactualizados o faltantes.
Las letras SQL de " MySQL " significan " Lenguaje de consulta estructurado " . SQL es el lenguaje
estandarizado más común utilizado para acceder a bases de datos.
Dependiendo de tu entorno de programación, podés ingresar SQL directamente (por ejemplo, para
generar informes), incrustar declaraciones SQL en código escrito en otro idioma o usar una API
específica del idioma que oculta la sintaxis SQL.
SQL está definido por el estándar ANSI / ISO SQL. El estándar SQL ha evolucionado desde 1986 y
existen varias versiones. Por ejemplo, “ SQL-92 ” se refiere al estándar publicado en 1992, “ SQL:
1999 ” se refiere al estándar publicado en 1999 y “ SQL: 2003 ” se refiere a la versión actual del
estándar. Usamos la frase " el estándar SQL " para referirnos a la versión actual del estándar SQL en
cualquier momento.
También puede ejecutarse cómodamente en una computadora de escritorio o portátil, junto con otras
aplicaciones, servidores web, etc., requiriendo poca o ninguna atención. Si dedicás una máquina
completa a MySQL, podés ajustar la configuración para aprovechar toda la memoria, la potencia de
la CPU y la capacidad de E / S disponible. MySQL también puede escalar a grupos de máquinas
conectadas en red.
MySQL Server se desarrolló originalmente para manejar grandes bases de datos mucho más rápido que
las soluciones existentes y se ha utilizado con éxito en entornos de producción muy exigentes durante
varios años. Aunque en constante desarrollo, MySQL Server ofrece hoy en día un conjunto de
funciones útiles y variadas. Su conectividad, velocidad y seguridad hacen que MySQL Server sea muy
adecuado para acceder a bases de datos en Internet.
El software de base de datos MySQL es un sistema cliente / servidor que consta de un servidor SQL
multiproceso que admite diferentes backends, varios programas cliente y bibliotecas diferentes,
herramientas administrativas y una amplia gama de interfaces de programación de aplicaciones (API).
MySQL Server, es también, como una biblioteca multiproceso integrada que puede vincular a su
aplicación para obtener un producto independiente más pequeño, más rápido y más fácil de
administrar.
MySQL Server tiene un conjunto práctico de características desarrolladas en estrecha colaboración con
usuarios de la comunidad. Es muy probable que tu aplicación o lenguaje de programación favorito sea
compatible con el servidor de base de datos MySQL.
Como su propio nombre indica, las bases de datos no relacionales son las que, a diferencia de las
relacionales, no tienen un identificador que sirva de relación entre un conjunto de
datos y otros.
Formatos
Diseño
esperar a que se relacione sola, porque eso no va a ocurrir. De nada sirve elegir la base de datos más
apropiada para nuestro sistema, si luego no se hace un buen diseño.
Se define una entidad (o instancia) como una unidad de una base de datos que contiene información.
Esta unidad es una representación dentro de la base de datos de un objeto, persona, empresa... etc, del
mundo real, y como tal posee ciertos atributos que la diferencian del resto de entidades. Así por
ejemplo, en una base de datos de una oficina, una entidad podría ser el material de oficina, otra los
empleados, otra los clientes, incluso el ambiente laboral, la empatía y cosas más abstractas. Cada una
de estas entidades tendría ciertos atributos propios. Así, los empleados tendrían atributos como
nombre, edad, estatura... las computadoras otros como un nro de serie, procesador, año de compra... y
así para cada una de ellas.
En una base de datos compleja pueden existir entidades relacionadas entre sí por diversos parámetros
o atributos, de tal modo que la existencia de una puede ir ligada a la existencia de otra. Así, las
entidades pueden ser fuertes (existen por sí mismas) o débiles (su existencia depende de que exista
otra entidad). Las relaciones entre entidades suelen describirse en el esquema de la estructura de la
base de datos e incluso pueden agruparse entre sí para formar conjuntos de entidades, también
llamados clases.
Tipos de relaciones
1 a N (uno a muchos)
Por ejemplo: una persona puede tener muchos autos y viceversa, muchos autos pueden ser de una
persona.
1 a 1 (uno a uno)
Por ejemplo: a un alumno le pertenece únicamente una libreta y viceversa, una libreta pertenece
únicamente a un alumno.
N a N (muchos a muchos)
Por ejemplo: muchos alumnos pueden tener muchas materias y viceversa, muchas materias pueden
contener a muchos alumnos.
3) Darle a next hasta llegar a la pantalla Authentication Method: Seleccionar Use Legacy
Authentication Method.
MYSQL WORKBENCH
MySQL Workbench es una herramienta visual de diseño de bases de datos que integra
desarrollo de software, Administración de bases de datos, diseño de bases de datos, creación y
mantenimiento para el sistema de base de datos MySQL.
Se puede descargar desde: https://dev.mysql.com/downloads/workbench/
PHPMYADMIN
Actualmente puede crear y eliminar Bases de Datos, crear, eliminar y alterar tablas, borrar,
editar y añadir campos, ejecutar cualquier sentencia SQL, administrar claves en campos,
administrar privilegios y exportar datos en varios formatos.
2) Cerrar y
volver a abrir Visual
Studio Code.
3)
Para invocar un programa MySQL desde la línea de comando (es decir, desde su shell o símbolo
del sistema CMD en Windows), ingresá a la carpeta en donde se instaló MySQL y escribí el nombre
del programa seguido de cualquier opción u otros argumentos necesarios para indicarle al programa
lo que desea que haga.
Por ejemplo:
mysqlshow --help
C:\> mysqldump -u root personnel
Los argumentos que comienzan con un guión simple o doble ( -, --) especifican las opciones del
programa. Las opciones suelen indicar el tipo de conexión que un programa debe realizar con el
servidor o afectar su modo operativo.
Los argumentos que no son de opción (argumentos sin guiones iniciales) proporcionan información
adicional al programa. Por ejemplo, el programa mysql interpreta el primer argumento que no es de
opción como un nombre de base de datos, por lo que el comando mysql --user=root test indica que
desea utilizar la test base de datos.
Las secciones posteriores que describen programas individuales indican qué opciones admite un
programa y describen el significado de cualquier argumento adicional que no sea de opción.
--host(o -h),
que especifican los parámetros de conexión. Indican el host donde se ejecuta el servidor MySQL y el
nombre de usuario y contraseña de su cuenta MySQL.
Todos los programas cliente de MySQL comprenden estas opciones; te permiten especificar a qué
servidor conectarse y la cuenta a utilizar en ese servidor.
Es probable que este sea el caso si obtiene un error de " programa no encontrado " cada vez que
intenta ejecutar un programa MySQL desde cualquier directorio que no sea el directorio bin. Para que
sea más conveniente usar MySQL, puede agregar el nombre de la ruta del directorio bin a la PATH
configuración de la variable de entorno. Eso le permite ejecutar un programa escribiendo solo su
nombre, no su ruta completa. Por ejemplo,
si mysql está instalado c:\Archivos\mysql\bin, podés ejecutar el programa invocándolo como mysql, y
no es necesario invocarlo como /c:\Archivos\mysql\bin .
Consultá en la web la documentación de los comandos que utiliza tu sistema operativo para obtener
instrucciones sobre cómo configurar tu variable PATH.
Después de modificar su configuración PATH, abrí una nueva ventana de consola en Windows
(CMD) o iniciá sesión nuevamente en Unix para que la configuración entre en vigor.
Las opciones del programa especificadas en la línea de comando siguen estas reglas:
Por ejemplo, -? y --help son las formas cortas y largas de la opción que le indica a un programa
MySQL que muestre su mensaje de ayuda.
● Para una opción larga que toma un valor, separá el nombre de la opción y el valor con un
signo =.
Para una opción corta que toma un valor, el valor de la opción puede seguir inmediatamente a la letra
de la opción, o puede haber un espacio entre: -hlocalhost y -h localhost son equivalentes. Una
excepción a esta regla es la opción para especificar tu contraseña de MySQL. Esta opción se puede
dar en forma larga como o como . En el último caso (sin ningún valor de contraseña dado), el
programa le solicita interactivamente la contraseña. La opción de contraseña también se puede dar en
forma abreviada como --password=pass_val o como --p pass_val.
Sin embargo, para la forma abreviada, si se proporciona el valor de la contraseña, debe seguir la
letra de la opción sin espacios intermedios : si un espacio sigue a la letra de la opción, el programa
no tiene forma de saber si se supone que el siguiente argumento es la contraseña valor o algún otro
tipo de argumento. En consecuencia, los dos comandos siguientes tienen dos significados
completamente diferentes:
mysql -ptest
mysql -p test
El primer comando le indica a mysql que use un valor de contraseña de test, pero no especifica una
base de datos predeterminada. El segundo indica a mysql que solicite el valor de la contraseña y que la
utilice test como base de datos predeterminada.
Dentro de los nombres de las opciones, el guión ( -) y el subrayado ( _) se pueden usar indistintamente.
Por ejemplo, --skip-grant-tables y --skip_grant_tables son
equivalentes. (Sin embargo, los guiones iniciales no se pueden dar como guiones bajos).
El servidor MySQL tiene ciertas opciones de comando que pueden especificarse solo al inicio, y un
conjunto de variables del sistema, algunas de las cuales pueden configurarse al inicio, en tiempo de
ejecución o ambos. Los nombres de las variables del sistema usan guiones bajos en lugar de guiones,
y cuando se hace referencia a ellos en tiempo de ejecución (por ejemplo, usando instrucciones SET
o SELECT), deben escribirse usando guiones bajos:
SET GLOBAL general_log = ON;
SELECT @@GLOBAL.general_log;
Al iniciar el servidor, la sintaxis de las variables del sistema es la misma que la de las opciones de
comando, por lo que dentro de los nombres de las variables, los guiones y los guiones bajos se
pueden usar indistintamente. Por ejemplo, --general_log=ON y -- general-log=ON son equivalentes.
(Esto también es cierto para las variables del sistema establecidas dentro de los archivos de
opciones).
Por ejemplo, el siguiente comando le dice a mysqladmin que haga ping al servidor 1024 veces,
durmiendo 10 segundos entre cada ping:
mysqladmin --count=1K --sleep=10 ping
Cuando especifique nombres de archivo como valores de opción, evite el uso del carácter
Los valores de opción que contienen espacios deben estar entre comillas cuando se dan en la línea
de comando. Por ejemplo, la opción --execute (ó -e) se puede utilizar
con mysql para pasar una o más sentencias SQL separadas por punto y coma al servidor. Cuando se
usa esta opción, mysql ejecuta las declaraciones en el valor de la opción y sale. Las declaraciones
deben ir entre comillas. Por ejemplo:
+ +
| VERSION() |
+ +
| 8.0.19 |
+ +
+ +
El servidor MySQL
mysqld es un archivo ejecutable (un programa). mysqld, también conocido como MySQL Server, es
un único programa multiproceso que hace la mayor parte del trabajo en una instalación de MySQL.
No genera procesos adicionales. MySQL Server administra el acceso al directorio de datos MySQL
que contiene bases de datos y tablas. El directorio de datos también es la ubicación predeterminada
para otra información, como archivos de registro y archivos de estado.
Cuando se inicia el servidor MySQL, escucha las conexiones de red de los programas cliente y
administra el acceso a las bases de datos en nombre de esos clientes.
MySQL Server también tiene un conjunto de variables del sistema que afectan su funcionamiento
mientras se ejecuta. Las variables del sistema se pueden configurar al iniciar el servidor y muchas de
ellas se pueden cambiar en tiempo de ejecución para efectuar la reconfiguración dinámica del
servidor.
MySQL Server también tiene un conjunto de variables de estado que brindan información sobre su
funcionamiento. Podés supervisar estas variables de estado para acceder a las características de
rendimiento en tiempo de ejecución.
El servidor MySQL, mysqld , tiene muchas opciones de comando y variables del sistema que se
pueden configurar al inicio para configurar su funcionamiento. Para determinar la opción de
comando predeterminada y los valores de las variables del sistema que utiliza el servidor, ejecutá
este comando:
El comando produce una lista de todas las opciones de mysqld y variables de sistema configurables.
Su salida incluye la opción predeterminada y los valores de las variables y se parece a esto:
abort-slave-event-count 0
allow-suspicious-udfs FALSE
archive ON
auto-increment-increment 1
auto-increment-offset 1
autocommit TRUE
automatic-sp-privileges TRUE
avoid-temporal-upgrade FALSE
back-log 80
basedir /home/jon/bin/mysql-8.0/
tmpdir /tmp
transaction-alloc-block-size 8192
transaction-isolation REPEATABLE-READ
transaction-prealloc-size 4096
transaction-read-only FALSE
transaction-write-set-extraction OFF
updatable-views-with-limit YES
validate-user-plugins TRUE
verbose TRUE
wait-timeout 28800
Para ver los valores actuales de las variables del sistema que realmente utiliza el servidor mientras se
ejecuta, conectate y ejecutá esta declaración:
Para ver algunos indicadores estadísticos y de estado de un servidor en ejecución, ejecutá esta
declaración:
La variable del sistema y la información de estado también están disponibles usando el comando
mysqladmin :
El servidor MySQL, mysqld , tiene muchas opciones de comando y variables del sistema que se
pueden configurar al inicio para configurar su funcionamiento. Para determinar la opción de
comando predeterminada y los valores de las variables del sistema que utiliza el servidor, ejecutá
este comando:
El comando produce una lista de todas las opciones de mysqld y variables de sistema configurables.
Su salida incluye la opción predeterminada y los valores de las variables y se parece a esto:
abort-slave-event-count 0
allow-suspicious-udfs FALSE
archive ON
auto-increment-increment 1
auto-increment-offset 1
autocommit TRUE
automatic-sp-privileges TRUE
avoid-temporal-upgrade FALSE
back-log 80
basedir /home/jon/bin/mysql-8.0/
tmpdir /tmp
transaction-alloc-block-size 8192
transaction-isolation REPEATABLE-READ
transaction-prealloc-size 4096
transaction-read-only FALSE
transaction-write-set-extraction OFF
updatable-views-with-limit YES
validate-user-plugins TRUE
verbose TRUE
wait-timeout 28800
Para ver los valores actuales de las variables del sistema que realmente utiliza el servidor mientras se
ejecuta, conectate y ejecutá esta declaración:
La variable del sistema y la información de estado también están disponibles usando el comando
mysqladmin :
Para que un programa cliente (MySQL Workbench, phpMyAdmin, VSCode, etc.) se conecte al
servidor MySQL, debés utilizar los parámetros de conexión adecuados, como el nombre del host donde
se ejecuta el servidor y el nombre de usuario y contraseña de tu cuenta MySQL.
Cada parámetro de conexión tiene un valor predeterminado, pero puede anular los valores
predeterminados según sea necesario utilizando las opciones del programa especificadas en la línea de
comandos o en un archivo de opciones.
Esta sección describe el uso de las opciones de la línea de comandos para especificar cómo
establecer conexiones con el servidor MySQL, para clientes
como mysql o mysqldump .
Para que un programa cliente se conecte al servidor MySQL, debés utilizar los parámetros de
conexión adecuados, como el nombre del host donde se ejecuta el servidor y el nombre de usuario y
contraseña de tu cuenta MySQL. Cada parámetro de conexión tiene un valor predeterminado, pero
puede anular los valores predeterminados según sea necesario utilizando las opciones del programa
especificadas en la línea de comandos o en un archivo de opciones.
Los siguiente ejemplos usan el programa cliente mysql , pero los principios se aplican a otros clientes
como mysqldump , mysqladmin o mysqlshow .
Este comando invoca a mysql sin especificar ningún parámetro de conexión explícito: mysql
● Para mysql , el primer argumento que no es de opción se toma como el nombre de la base de
datos predeterminada. Como no existe tal argumento, mysql no selecciona una base de datos
predeterminada.
Para especificar el nombre de host y el nombre de usuario de forma explícita, así como una
contraseña, proporcioná las opciones adecuadas en la línea de comandos. Para seleccionar una base
de datos predeterminada, incorporá un argumento de nombre de base de datos.
Ejemplos:
mysql --host=localhost --user=myname --password=password mydb mysql -h
● Para especificar explícitamente que no hay contraseña y que el programa cliente no debe
solicitar una, use la opción --skip-password.
En algunos sistemas, la rutina de la biblioteca que utiliza MySQL para solicitar una contraseña limita
automáticamente la contraseña a ocho caracteres. Esa limitación es una propiedad de la biblioteca del
sistema, no MySQL. Internamente, MySQL no tiene ningún límite para la longitud de la contraseña.
Otra solución es cambiar tu contraseña de MySQL a un valor que tenga ocho o menos caracteres, pero
que tiene la desventaja de que las contraseñas más cortas tienden a ser menos seguras.
Los programas cliente determinan qué tipo de conexión realizar de la siguiente manera:
● Si el host no se especifica o lo está localhost, se produce una conexión con el host local:
● Solo se utilizan o verifican las opciones de conexión que son relevantes para el protocolo de
transporte seleccionado. Se ignoran otras opciones de conexión. Por ejemplo, --
host=localhost en Unix, el cliente intenta conectarse al servidor local utilizando un archivo de
socket Unix, incluso si se da una opción --p o -P para especificar un número de puerto TCP /
IP.
Para asegurarse de que el cliente realiza una conexión TCP / IP con el servidor local, utilice --
host o -h para especificar un valor de nombre de host de 127.0.0.1(en lugar
de localhost), o la dirección IP o el nombre del servidor local. También puede especificar el
protocolo de transporte explícitamente, incluso para localhost, utilizando la opción -- protocol=TCP.
Ejemplos:
protocol=TCP
Las conexiones a servidores remotos utilizan TCP / IP. Este comando se conecta al servidor en
ejecución remote.example.com utilizando el número de puerto predeterminado (3306):
mysql --host=remote.example.com
Para especificar un número de puerto explícitamente, use la opción --port o -P: mysql --
host=remote.example.com --port=13306
Para este comando, el programa usa un archivo de socket en Unix y la --port opción se ignora:
Para hacer que se utilice el número de puerto, fuerce una conexión TCP / IP. Por ejemplo, invoque el
programa de cualquiera de estas formas:
port=13306 –protocol=TCP
[create_option] ...
create_option: [DEFAULT] { CHARACTER SET
[=] charset_name
| COLLATE [=] collation_name
| ENCRYPTION [=] {'Y' | 'N'}
CREATE DATABASE crea una base de datos con el nombre de indicado en esa orden. Para utilizar esta
declaración, se necesita el privilegio o permiso del sistema de la base de datos. CREATE SCHEMAes
DATABASE no está permitido dentro de una sesión que tiene una declaración activa LOCK
TABLES .
Cada create_option especifica una característica de la base de datos. Las características de la base de
Para ver los conjuntos de caracteres y las intercalaciones disponibles, utilizá las instrucciones
predeterminado, que es heredado por las tablas creadas en la base de datos. Los valores permitidos son
'Y' (cifrado activado) y 'N' (cifrado desactivado). Si la opción ENCRYPTION no se especifica , el
de datos.
Una base de datos en MySQL se implementa como un directorio que contiene archivos que
corresponden a tablas en la base de datos. Debido a que no hay tablas en una base de datos cuando se
crea inicialmente, la declaración CREATE DATABASE crea solo un directorio bajo el directorio
de datos MySQL. Si el nombre de una base de datos contiene caracteres especiales, el nombre del
directorio de datos (por ejemplo, con mkdir ) no es compatible con MySQL 8.0.
Al crear una base de datos, dejá que el servidor administre el directorio y los archivos que contiene. La
resultados inesperados.
MySQL no tiene límite en la cantidad de bases de datos. El sistema de archivos subyacente puede tener
un límite en el número de directorios.
SHOW TABLES;
Crear una base de datos de prueba
WORLD.SQL
Los pasos se detallan para VSCode pero para MySQL Workbench y phpMyAdmin resultan similares.
1) Descargar world.sql del Aula Virtual y abrir con Visual Studio Code.
2) Apretar botón derecho -> Run SQL Query.
3) Apretar botón
derecho -> Run
SQL Query.
Sentencia
CREATE
TABLE
De forma predeterminada, las tablas se crean en la base de datos predeterminada, utilizando el motor
InnoDB de almacenamiento. Se produce un error si la tabla existe, si no hay una base de datos
predeterminada o si la base de datos no existe.
MySQL no tiene límite en el número de tablas. El sistema de archivos subyacente puede tener un límite
en la cantidad de archivos que representan tablas. Los motores de almacenamiento individuales pueden
imponer restricciones específicas del motor. InnoDB permite hasta 4 mil millones de tablas.
Hay varios aspectos importantes de CREATE TABLE, descritos en los siguientes temas de esta
sección:
Nombre de la tabla
tbl_name
El nombre de la tabla se puede especificar db_name.tbl_name para crear la tabla en una base
de datos específica. Esto funciona independientemente de si existe una base de datos
predeterminada, asumiendo que la base de datos existe. Si utiliza identificadores entre comillas,
cite los nombres de la base de datos y de la tabla por separado. Por ejemplo, escribe
`mydb`.`mytbl`, no `mydb.mytbl`.
IF NOT EXISTS
Evita que se produzca un error si la tabla existe. Sin embargo, no se verifica que la tabla existente
tenga una estructura idéntica a la indicada por el CREATE TABLE.
Tablas temporales
Puede utilizar la palabra clave TEMPORARY al crear una tabla. Una tabla TEMPORARY es
visible sólo dentro de la sesión actual y se elimina automáticamente cuando se cierra la sesión.
LIKE
Usá CREATE TABLE ... LIKE para crear una tabla vacía basada en la definición de otra tabla,
incluidos los atributos e índices de columna definidos en la tabla original:
CREATE TABLE destino_tbl LIKE origen_tbl;
[AS] query_expression
Para crear una tabla a partir de otra, agregá una declaración SELECT al final de la CREATE
TABLE declaración:
CREATE TABLE destino_tbl AS SELECT * FROM origen_tbl;
IGNORE | REPLACE
Las opciones IGNORE y REPLACE indican cómo manejar filas que duplican valores clave únicos
al copiar una tabla usando una declaración SELECT.
Hay un límite estricto de 4096 columnas por tabla, pero el máximo efectivo puede ser menor para una
tabla dada y depende de los factores de soporte del sistema operativo y hardware.
data_type
Tipos de datos de caracteres ( CHAR, VARCHAR, los tipos TEXT, ENUM, SET, y
cualquier sinónimo) pueden incluir CHARACTER SET para especificar el conjunto de
caracteres para la columna. CHARSET es sinónimo de CHARACTER SET. Se puede
especificar una colación para el juego de caracteres con el atributo COLLATE, junto con
cualquier otro atributo. Ejemplo:
CREATE TABLE mitabla (micolumna CHAR(20) CHARACTER SET utf8 COLLATE
utf8_bin);
Para columnas CHAR, VARCHAR, BINARY, y VARBINARY, los índices pueden ser
creados para el uso de sólo la parte principal de los valores de columna, utilizando la sintaxis
para especificar un índice de longitud de prefijo, y aunque las columnas también se pueden
indexar, se debe dar una longitud de prefijo . Por ejemplo:
CREATE TABLE mitabla (micolumna BLOB, INDEX(blob_col(10)));
Para un índice no único, se produce un error (si el modo SQL estricto está habilitado) o
la longitud del índice se reduce para que se encuentre dentro del tamaño máximo de
tipo de datos de columna y se genera una advertencia (si el modo SQL estricto no está
habilitado).
JSON las columnas no se pueden indexar. Podés solucionar esta restricción creando un índice
en una columna generada que extraiga un valor de la columna JSON.
En MySQL 8.0, sólo los motores de almacenamiento InnoDB, MyISAMy MEMORY soportan
índices en columnas que pueden tener NULLvalores. En otros casos, deberás declarar las
columnas indexadas como NOT NULL o tendrás como resultado de un error.
DEFAULT
AUTO_INCREMENT
Para recuperar un valor AUTO_INCREMENT después de insertar una fila, usá la función
SQL LAST_INSERT_ID() o la función API de C mysql_insert_id().
Solo puede haber una columna AUTO_INCREMENT por tabla, debe estar indexada y no puede
tener un valor DEFAULT. Una columna AUTO_INCREMENT funciona correctamente si
contiene sólo valores positivos. Se considera que insertar un número negativo es insertar un
número positivo muy grande. Esto se hace para evitar problemas de precisión cuando los
números " pasan " de positivo a negativo y también para garantizar que no obtengas
accidentalmente una columna AUTO_INCREMENT que contenga 0.
Por ejemplo:
SELECT * FROM mitabla WHERE auto_columna IS NULL
COMMENT
Se puede especificar un comentario para una columna con la opción COMMENT, hasta 1024
caracteres. El comentario se muestra mediante las declaraciones SHOW CREATE TABLE
y SHOW FULL COLUMNS.
PRIMARY KEY
Un índice único donde todas las columnas clave deben definirse como NOT NULL. Si no se
declaran explícitamente como NOT NULL, MySQL los declara implícitamente (y
silenciosamente). Una tabla sólo puede tener una PRIMARY KEY. El nombre de
la PRIMARY KEY es siempre PRIMARY, por lo que no se puede utilizar como nombre para
ningún otro tipo de índice.
Si no tiene un PRIMARY KEY y una aplicación solicita el PRIMARY KEY en sus tablas,
MySQL devuelve el primer UNIQUE índice que no tiene columnas NULL como PRIMARY
KEY.
En la tabla creada,primero se coloca a PRIMARY KEY, seguido de todos los índices UNIQUE y
luego los índices no únicos. Esto ayuda al optimizador de MySQL a priorizar qué índice usar y
también más rápidamente y a detectar claves UNIQUE duplicadas .
PRIMARY KEY puede ser un índice de varias columnas. Sin embargo, no puede crear un
índice de varias columnas utilizando el atributo clave PRIMARY KEY en una especificación de
columna. Si lo hace, solo marcará esa columna como principal. Debe utilizar
una cláusula separada . PRIMARY KEY(key_part, ...)
KEY | INDEX
UNIQUE
Un índice UNIQUE crea una restricción tal que todos los valores del índice deben ser distintos.
Se produce un error si intenta agregar una nueva fila con un valor clave que coincide con una fila
existente. Para todos los motores, un índice UNIQUE permite múltiples
valores NULL para las columnas que pueden contener NULL. Si especifica un valor de
prefijo para una columna en un índice UNIQUE, los valores de columna deben ser únicos
dentro de la longitud del prefijo.
FULLTEXT
MySQL admite claves externas, que le permiten realizar referencias cruzadas de datos
relacionados entre tablas y restricciones de claves externas, que ayudan a mantener la
coherencia de estos datos dispersos.
Las tablas particionadas que emplean el motor InnoDB de almacenamiento no admiten claves
externas.
key_part
Una especificación key_part puede terminar con ASC o DESC para especificar si los
valores de índice se almacenan en orden ascendente o descendente. El valor
predeterminado es ascendente si no se proporciona un especificador de orden.
DESCRIBE alumnos;
Aparecerá lo siguiente:
Por ejemplo, en la tabla clientes el dni es una primary key, pero en una tabla “pedidos” representa a
quién pertenece ese determinado pedido.
nuevamente:
Aparece un mensaje de error, indicando que no existe, ya que intentamos borrar una tabla inexistente.
Para evitar este mensaje podemos tipear:
columna:
una columna:
COLUMN nombre_de_columna;
nuevamente:
Aparece un mensaje de error, indicando que no existe, ya que intentamos borrar una tabla inexistente.
Para evitar este mensaje podemos tipear:
columna:
una columna:
COLUMN nombre_de_columna;
Tipos de datos
MySQL admite tipos de datos SQL en varias categorías: tipos numéricos, tipos de fecha y hora, tipos
de cadenas (caracteres y bytes), tipos espaciales y el JSON tipo de
datos. Este capítulo proporciona una descripción general y más detallada de las propiedades de los
tipos en cada categoría, y un resumen de los requisitos de almacenamiento de tipos de datos. Las
descripciones iniciales son intencionalmente breves. Consulte las descripciones más detalladas para
obtener información adicional sobre tipos de datos particulares, como los formatos permitidos en los
que puede especificar valores.
Para los tipos enteros, M indica el ancho máximo de visualización. Para los tipos de coma
flotante y de coma fija, M es el número total de dígitos que se pueden almacenar (la precisión).
Para los tipos de cadena, M es la longitud máxima. El valor máximo permitido de M depende del
tipo de datos.
D se aplica a los tipos de coma flotante y de coma fija e indica el número de dígitos que siguen al
punto decimal (la escala). El valor máximo posible es 30, pero no debe ser mayor que M-2.
Fsp se aplica a la TIME, DATETIME y TIMESTAMP los tipos y representa la precisión de
fracciones de segundo; es decir, el número de dígitos que siguen al punto decimal en fracciones de
segundos. El fspvalor, si se da, debe estar en el rango de 0 a 6. Un valor de 0 significa que no hay
una parte fraccionaria. Si se omite, la precisión predeterminada es 0 (esto difiere del estándar SQL
predeterminado de 6, por compatibilidad con versiones anteriores de MySQL).
Para un almacenamiento óptimo, debe intentar utilizar el tipo más preciso en todos los casos. Por
ejemplo, si se usa una columna de números enteros para valores en el rango de 1a 99999,
MEDIUMINT UNSIGNED es el mejor tipo. De los tipos que representan todos los valores
requeridos, este tipo utiliza la menor cantidad de almacenamiento.
Todos los cálculos básicos ( +, -, *, y /) con DECIMAL columnas se realizan con precisión de 65
decimales (base 10) dígitos.
el tipo DOUBLE puede ser lo suficientemente bueno. Para una alta precisión, siempre puede
convertir a un tipo de punto fijo almacenado en un BIGINT. Esto le permite hacer todos los cálculos
con números enteros de 64 bits y luego convertir los resultados a valores de punto flotante según sea
necesario.
Tipos numéricos:
Existen tipos de datos numéricos, que se pueden dividir en dos grandes grupos, los que están en coma
flotante (con decimales) y los que no.
TinyInt:
Es un número entero con o sin signo. Con signo el rango de valores válidos va desde -128 a 127. Sin
signo, el rango de valores es de 0 a 255
Bit ó Bool:
Un número entero que puede ser 0 ó 1 SmallInt:
Número entero con o sin signo. Con signo el rango de valores va desde -32768 a 32767. Sin signo, el
rango de valores es de 0 a 65535.
MediumInt:
Número entero con o sin signo. Con signo el rango de valores va desde -8.388.608 a 8.388.607. Sin
signo el rango va desde 0 a16777215.
Integer, Int:
Número entero con o sin signo. Con signo el rango de valores va desde -2147483648 a 2147483647.
Sin signo el rango va desde 0 a 429.4967.295
BigInt:
Número entero con o sin signo. Con signo el rango de valores va desde - 9.223.372.036.854.775.808 a
9.223.372.036.854.775.807. Sin signo el rango va desde 0 a 18.446.744.073.709.551.615.
Float:
Número pequeño en coma flotante de precisión simple. Los valores válidos van desde -
3.402823466E+38 a -1.175494351E-38, 0 y desde 1.175494351E-38 a
3.402823466E+38.
xReal, Double:
Número en coma flotante de precisión doble. Los valores permitidos van desde -
1.7976931348623157E+308 a -2.2250738585072014E-308, 0 y desde
2.2250738585072014E-308 a 1.7976931348623157E+308
Tipo de Tamaño de
Campo Almacenamien
to
TINYINT 1 byte
SMALLINT 2 bytes
MEDIUMIN 3 bytes
T
INT 4 bytes
INTEGER 4 bytes
BIGINT 8 bytes
FLOAT(X) 4 ú 8 bytes
FLOAT 4 bytes
DOUBLE 8 bytes
DOUBL
8 bytes
E
PRECISI
ON
REAL 8 bytes
A la hora de almacenar fechas, hay que tener en cuenta que Mysql no comprueba de una manera
estricta si una fecha es válida o no. Simplemente comprueba que el mes esta comprendido entre 0 y 12
y que el día esta comprendido entre 0 y 31.
Date:
Tipo fecha, almacena una fecha. El rango de valores va desde el 1 de enero del 1001 al 31 de
diciembre de 9999. El formato de almacenamiento es de año-mes-dia
DateTime:
Combinación de fecha y hora. El rango de valores va desde el 1 de enero del 1001 a las 0 horas, 0
minutos y 0 segundos al 31 de diciembre del 9999 a las 23 horas, 59 minutos y 59 segundos. El
formato de almacenamiento es de año-mes-dia horas:minutos:segundos
TimeStamp:
Combinación de fecha y hora. El rango va desde el 1 de enero de 1970 al año 2037. El formato de
almacenamiento depende del tamaño del campo:
Tam
Formato
a
ñ
o
AñoMesDiaHoraMinutoSegun
14
do aaaammddhhmmss
AñoMesDiaHoraMinutoSegun
12
do aammddhhmmss
8 ñoMesDia aaaammdd
6 AñoMesDia aammdd
4 AñoMes aamm
2 Año aa
Time:
Almacena una hora. El rango de horas va desde -838 horas, 59 minutos y 59 segundos a 838, 59
minutos y 59 segundos. El formato de almacenamiento es de 'HH:MM:SS'
Year:
Almacena un año. El rango de valores permitidos van desde el año 1901 al año 2155. El campo puede
tener tamaño dos o tamaño 4 dependiendo de si queremos almacenar el año con dos o cuatro dígitos.
Tamaño de
Tipo
Almacenamie
de
nt o
Cam
po
DATE 3
bytes
DATETIM 8
E bytes
TIMESTA 4
MP bytes
TIME 3
bytes
YEAR 1 byte
Tipos de cadena:
Char(n):
Almacena una cadena de longitud fija. La cadena podrá contener desde 0 a 255 caracteres.
VarChar(n):
Almacena una cadena de longitud variable. La cadena podrá contener desde 0 a 255 caracteres.
Dentro de los tipos de cadena se pueden distinguir otros dos subtipos, los tipo Test y los tipo BLOB
(Binary large Object)
La diferencia entre un tipo y otro es el tratamiento que reciben a la hora de realizar ordenamientos y
comparaciones. Mientras que el tipo test se ordena sin tener en cuenta las mayúsculas y las
minúsculas, el tipo BLOB se ordena teniéndose en cuenta.
Los tipos BLOB se utilizan para almacenar datos binarios como pueden ser ficheros. TinyText y
TinyBlob:
Text:
MediumBlob y MediumText:
LongText:
Un texto con un máximo de caracteres 4.294.967.295. Hay que tener en cuenta que debido a los
protocolos de comunicación los paquetes pueden tener un máximo de 16 Mb.
Enum:
Campo que puede tener un único valor de una lista que se especifica. El tipo Enum acepta hasta
65535 valores distintos
Set:
Un campo que puede contener ninguno, uno o varios valores de una lista. La lista puede tener un
máximo de 64 valores.
Tipo de Tamaño de
campo Almacenamiento
CHAR(n) n bytes
VARCHAR(n) n +1 bytes
TINYBLOB,
Longitud+1 bytes
TINYTEXT
MEDIUMBLO
Longitud +3 bytes
B,
MEDIUMTEX
T
LONGBL
Longitud +4 bytes
OB,
LONGTE
XT
ENUM('value1','va 1 ó dos bytes dependiendo del número
l ue2',...) de valores