0% encontró este documento útil (0 votos)
89 vistas43 páginas

Unidad BASE DE DATOS

El documento describe MySQL, un popular sistema de gestión de bases de datos de código abierto. MySQL almacena datos en tablas relacionadas dentro de bases de datos y usa el lenguaje SQL para agregar, acceder y procesar datos. Es software libre que puede descargarse gratis y también está disponible con licencias comerciales. MySQL es un servidor rápido y escalable para bases de datos.

Cargado por

fscuzzalopez
Derechos de autor
© © All Rights Reserved
Nos tomamos en serio los derechos de los contenidos. Si sospechas que se trata de tu contenido, reclámalo aquí.
Formatos disponibles
Descarga como PDF, TXT o lee en línea desde Scribd
0% encontró este documento útil (0 votos)
89 vistas43 páginas

Unidad BASE DE DATOS

El documento describe MySQL, un popular sistema de gestión de bases de datos de código abierto. MySQL almacena datos en tablas relacionadas dentro de bases de datos y usa el lenguaje SQL para agregar, acceder y procesar datos. Es software libre que puede descargarse gratis y también está disponible con licencias comerciales. MySQL es un servidor rápido y escalable para bases de datos.

Cargado por

fscuzzalopez
Derechos de autor
© © All Rights Reserved
Nos tomamos en serio los derechos de los contenidos. Si sospechas que se trata de tu contenido, reclámalo aquí.
Formatos disponibles
Descarga como PDF, TXT o lee en línea desde Scribd
Está en la página 1/ 43

MySQL

1. Entorno MySQL
2. PhpMyAdmin
3. Workbench.
4. Acceso a un servidor de Base de datos de prueba.
5. Crear, eliminar y seleccionar una base de datos.
6. Crear, eliminar y seleccionar una tabla.
7. Concepto de Entidad, atributo y tipo de datos.
8. Estructura de una consulta sql y Cláusula SELECT
9. Alias de Tablas
10. Cláusula FROM y Cláusula WHERE
11. Cláusula Insert / Delete y Update
¿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.

MySQL es un sistema de gestión de bases de datos.

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.

El software MySQL es de código abierto.

Código abierto significa que cualquiera puede utilizar y modificar el software. Cualquiera puede
descargar el software MySQL de Internet y usarlo sin pagar nada. Si lo deseas, podés estudiar el
código fuente y modificarlo para adaptarlo a tus necesidades. El software MySQL utiliza la GPL
(Licencia Pública General GNU), http://www.fsf.org/licenses/ , para definir lo que podés y no podés
hacer con el software en diferentes situaciones. Si no te sentís cómodo con la GPL o necesitás
incrustar código MySQL en una aplicación comercial, se puede adquirir una versión con licencia
comercial. Para ello hay una descripción general de licencias de MySQL en
http://www.mysql.com/company/legal/licensing/.

MySQL es un servidor de base de datos muy rápido, confiable, escalable y fácil de usar.
También puede ejecutarse cómodamente en una computadora de escritorio o portátil, junto con tus
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.

MySQL Server funciona en sistemas cliente / servidor o integrados.

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.

Hay disponible una gran cantidad de software MySQL contribuido.

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.

Concepto de Entidad

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 si 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 si 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 si para formar conjuntos de entidades, también
llamados clases.

El modelo Entidad-Relación es de hecho uno de los más importantes a la hora de diseñar e


implementar una base de datos con éxito. Mediante este modelo se relacionan una o varias
entidades por sus atributos, que pueden ser comunes o no a varias de ellas.
Invocar programas MySQL
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.
Los siguientes comandos muestran algunas invocaciones de programas de muestra.
C:\> representa la solicitud de su intérprete de comandos ( CMD en Windows); no es parte de lo
que se escribe. El indicador particular que ve depende de su intérprete de comandos. Las solicitudes
típicas son: Linux/ Unix / Mac $para sh , ksh o bash , %para csh o tcsh y C:\>para los intérpretes de
comandos Windows DOS o cmd .
Por ejemplo:
C:\> mysql --user=root test
C:\> mysqladmin extended-status variables
C:\> 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.
Algunas opciones son comunes a varios programas.
Las más utilizadas son las opciones
--host(o -h),
--user(o -u) y --password(o -p)

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.
Otras opciones de conexión son:
--port(o -P) especificar un número de puerto TCP / IP y
--socket(o-S) para especificar un archivo de socket Unix en Unix (o un nombre de canalización con
nombre en Windows).
Puede resultar necesario invocar programas MySQL utilizando el nombre de la ruta al directorio bin
en el que están instalados.
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.
Uso de opciones en la línea de comandos
Las opciones del programa especificadas en la línea de comando siguen estas reglas:
• Las opciones se dan después del nombre del comando.
• Un argumento de opción comienza con un guión o dos guiones, dependiendo de si es una forma
corta o larga del nombre de la opción. Muchas opciones tienen formas cortas y largas.
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.
• Los nombres de las opciones distinguen entre mayúsculas y minúsculas. -v y -V son legales y
tienen diferentes significados. (Son las formas breves correspondientes de las opciones --verbose
y --version).
• Algunas opciones toman un valor después del nombre de la opción. Por ejemplo, -h localhost
o --host=localhost indican el host del servidor MySQL a un programa cliente. El valor de la opción
le dice al programa el nombre del host donde se ejecuta el servidor MySQL.
• 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 ~meta de

shell. Puede que no se interprete como esperaba.

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:

shell> mysql -u root -p -e "SELECT VERSION();SELECT NOW()"


Enter password: ******
+----------------+
| VERSION() |
+----------------+
| 8.0.19 |
+----------------+
+---------------------+
| NOW() |
+--------------------------+
| 2019-09-03 10:36:48 |
+--------------------------+
shell>

Nota: La forma larga ( --execute) va seguida de un signo igual ( =). Para usar valores entre
comillas dentro de una declaración, debe escapar de las comillas internas o usar un tipo de
comillas diferente dentro de la declaración de las que se usan para citar la declaración en
sí. Las capacidades de su procesador de comandos dictan sus opciones sobre si puede usar
comillas simples o dobles y la sintaxis para escapar de los caracteres de comillas. Por
ejemplo, si su procesador de comandos admite comillas con comillas simples o dobles,
puede utilizar comillas dobles alrededor de la declaración y comillas simples para cualquier
valor entre comillas dentro de la declaración. Por ej: “ ’ Hola Mundo ‘ “
Conectarse al servidor MySQL mediante opciones de comando
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
Como no hay opciones de parámetros, se aplican los valores predeterminados:
• El nombre de host predeterminado es localhost.
• El nombre de usuario predeterminado está en el ODBC (estándar de acceso a las bases de datos)
en Windows o su nombre de inicio de sesión de Unix en Unix.
• No se envía contraseña porque no se da --password ni -p .
• 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 localhost -u myname -ppassword mydb
Para las opciones de contraseña, el valor de la contraseña es opcional:
• Si utiliza una opción --password o -p y especifica un valor de contraseña, no debe haber ningún
espacio entre --password=o -p y la contraseña que le sigue.
• Si usa --password o -p pero no especifica un valor de contraseña, el programa cliente le solicita
que ingrese la contraseña. La contraseña no se muestra cuando la ingresa. Esto es más seguro que
dar la contraseña en la línea de comando, lo que podría permitir a otros usuarios de su sistema ver la
línea anterior de comando simplemente apretando la flecha arriba del teclado y accediendo al
historial de órdenes ingresadas .
• Para especificar explícitamente que no hay contraseña y que el programa cliente no debe
solicitar una, use la opción --skip-password .
Como se acaba de mencionar, incluir el valor de la contraseña en la línea de comando es un riesgo
para la seguridad. Para evitar este riesgo, especifique la opción --password o -p sin ningún valor de
contraseña siguiente:
mysql --host=localhost --user=myname --password mydb
mysql -h localhost -u myname -p mydb
Cuando se da la opción --password o -p sin valor de contraseña, el programa cliente imprime un
mensaje y espera a que ingrese la contraseña. (En estos ejemplos, mydb no se ha interpretado como
una contraseña, ya que está separada de la precedente opción de contraseña por un espacio.)
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:
◦ En Windows, el cliente se conecta mediante memoria compartida, si el servidor se inició con
la variable shared_memory del sistema habilitada para admitir conexiones de memoria compartida.
◦ En Unix, los programas MySQL tratan el nombre de host localhost de manera especial, de
una manera que probablemente sea diferente de lo que espera en comparación con otros programas
basados en la red: el cliente se conecta mediante un archivo de socket Linux.
• En Windows, si host es . (punto), o TCP / IP no está habilitado y --socket no se especifica o el
host está vacío, el cliente se conecta mediante con nombre, si el servidor se inició con la variable
named_pipe del sistema habilitada para admitir conexiones con nombre . Si no se admiten las
conexiones de canalización con nombre o si el usuario que realiza la conexión no es miembro del
grupo de Windows especificado por la named_pipe_full_access_group variable del sistema, se
produce un error.
• De lo contrario, la conexión utiliza TCP / IP.
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:
mysql --host=127.0.0.1
mysql --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
También puede especificar un número de puerto para las conexiones a un servidor local. Sin
embargo, como se indicó anteriormente, las conexiones localhost en Unix usan un archivo de socket
de forma predeterminada, por lo que, a menos que fuerce una conexión TCP / IP como se describió
anteriormente, se ignorará cualquier opción que especifique un número de puerto.
Para este comando, el programa usa un archivo de socket en Unix y la --port opción se ignora:
mysql --port=13306 --host=localhost
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:
mysql --port=13306 --host=127.0.0.1
mysql --port=13306 –protocol=TCP
mysqld : el servidor MySQL
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.
El programa mysqld tiene muchas opciones que se pueden especificar al inicio.
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.

Configuración del servidor


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:
c:\> mysqld --verbose --help
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:
mysql> SHOW VARIABLES;
Para ver algunos indicadores estadísticos y de estado de un servidor en ejecución, ejecutá esta
declaración:
mysql> SHOW STATUS;
La variable del sistema y la información de estado también están disponibles usando el comando
mysqladmin :
shell> mysqladmin variables
shell> mysqladmin extended-status
Creando una Base de Datos
CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name
[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 sinónimo de .CREATE DATABASE

Se produce un error si la base de datos ya existe y no le especificaste IF NOT EXISTS.

CREATE 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 datos se almacenan en el diccionario de datos.

La opción CHARACTER SET especifica el juego de caracteres predeterminado de la base


de datos. La COLLATE opción especifica la clasificación de la base de datos predeterminada.

Para ver los conjuntos de caracteres y las intercalaciones disponibles, utilizá

las instrucciones SHOW CHARACTER SET y SHOW COLLATION, respectivamente.

La opción ENCRYPTION, introducida en MySQL 8.0.16, define el cifrado de base de

datos 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 valor de la variable del sistema default_table_encryption define el cifrado

predeterminado de la base 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 la base de datos contiene versiones codificadas de esos caracteres.

La creación de un directorio de base de datos mediante la creación manual de un directorio en el

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 manipulación de archivos y directorios de bases de datos directamente puede provocar

inconsistencias y 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.

También podés utilizar el programa mysqladmin para crear bases de datos.


Sentencia CREATE TABLE
CREATE TABLE crea una tabla con el nombre especificado. Debes tener el privilegio /

permiso CREATE para crear una tabla.

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 solo dentro de la sesión actual y se elimina automáticamente cuando se cierra la sesión.

Clonación y copia de tablas

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.

Atributos y tipos de datos de columna

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 hadware.

data_type
data_type representa el tipo de datos en una definición de columna.

Algunos atributos no se aplican a todos los tipos de datos. AUTO_INCREMENT se aplica

solo a los tipos enteros y de coma flotante. Antes de MySQL 8.0.13, DEFAULT no se aplicaba a

los BLOB, TEXT, GEOMETRY, y tipos JSON.

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);
MySQL 8.0 interpreta las especificaciones de longitud en las definiciones de columna de caracteres

en caracteres.
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)));


Si un prefijo de índice especificado excede el tamaño máximo de tipo de datos de

columna, CREATE TABLE maneja el índice de la siguiente manera:

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).

Para un índice exclusivo, se produce un error independientemente del modo SQL porque la

reducción de la longitud del índice puede permitir la inserción de entradas no únicas que no

cumplen con el requisito de unicidad especificado.

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.

NOT NULL | NULL

Si no se especifica NULL ni NOT NULL, la columna se trata como si se hubiera

especificado NULL.

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

Especifica un valor predeterminado para una columna.

Si el modo NO_ZERO_DATE o NO_ZERO_IN_DATE SQL está habilitado y un valor

predeterminado de fecha no es correcto de acuerdo con ese modo, CREATE TABLE produce una

advertencia si el modo SQL estricto no está habilitado y un error si el modo estricto está

habilitado. Por ejemplo, con NO_ZERO_IN_DATE habilitado, produce una advertencia.

AUTO_INCREMENT
Una columna de número entero o de punto flotante puede tener el atributo

adicional AUTO_INCREMENT. Cuando insertás un valor de NULL(recomendado) o 0 en

una columna indexada AUTO_INCREMENT , la columna se establece en el siguiente valor de

secuencia. Por lo general, esto es value+1, donde value está el valor más grande para la columna

actualmente en la tabla. Las secuencias AUTO_INCREMENT comienzan con 1.

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().

Si el modo SQL NO_AUTO_VALUE_ON_ZERO está habilitado, podés almacenar 0

en columnas AUTO_INCREMENT como 0 sin generar un nuevo valor de secuencia.

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

solo 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 ej:

SELECT * FROM mitabla WHERE auto_columna IS NULL


Este método requiere que la variable sql_auto_is_null no se establezca en 0.

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 solo puede tener una PRIMARY KEY. El nombre de a 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

KEY es normalmente un sinónimo de INDEX. El atributo de clave PRIMARY KEY también se

puede especificar KEY cuando se proporciona en una definición de columna. Esto se implementó

por compatibilidad con otros sistemas de bases de datos.

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

Un FULLTEXTíndice es un tipo especial de índice que se utiliza para búsquedas de texto

completo. Solo los motores de almacenamiento InnoDB y MyISAM admiten

índices FULLTEXT. Ellos sólo se pueden crear a partir de

columnas CHAR, VARCHARy TEXT. La indexación siempre ocurre en toda la columna; la

indexación de prefijo de columna no es compatible y cualquier longitud de prefijo se ignora si se

especifica.

FOREIGN KEY

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.


Tipos de datos

Tabla de contenido

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.

Las descripciones de los tipos de datos utilizan estas convenciones:

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.

Dse 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).

Los corchetes ( [y ]) indican partes opcionales de las definiciones de tipo.

Elegir el tipo correcto para una columna


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.

Si la precisión no es demasiado importante o si la velocidad es la máxima prioridad, 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
Decimal, Dec, Numeric:
Número en coma flotante desempaquetado. El número se almacena como una cadena

Tamaño de
Tipo de Campo
Almacenamiento
TINYINT 1 byte
SMALLINT 2 bytes
MEDIUMINT 3 bytes
INT 4 bytes
INTEGER 4 bytes
BIGINT 8 bytes
FLOAT(X) 4 ú 8 bytes
FLOAT 4 bytes
DOUBLE 8 bytes
DOUBLE
8 bytes
PRECISION
REAL 8 bytes
M+2 bytes sí D > 0,
DECIMAL(M,D
M+1 bytes sí D = 0
NUMERIC(M,D M+2 bytes if D > 0,
) M+1 bytes if D = 0

2 Tipos fecha:
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:

Tamaño Formato
14 AñoMesDiaHoraMinutoSegundo
aaaammddhhmmss
AñoMesDiaHoraMinutoSegundo
12
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 va 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.

Tipo de Tamaño de
Campo Almacenamiento
DATE 3 bytes
DATETIME 8 bytes
TIMESTAMP 4 bytes
TIME 3 bytes
YEAR 1 byte

3 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éndolas en cuenta.
Los tipos BLOB se utilizan para almacenar datos binarios como pueden ser ficheros.
TinyText y TinyBlob:
Columna con una longitud máxima de 255 caracteres.
Blob y Text:
Un texto con un máximo de 65535 caracteres.
MediumBlob y MediumText:
Un texto con un máximo de 16.777.215 caracteres.
LongBlob y 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 ó varios valores de una lista. La lista puede tener un
máximo de 64 valores.

Tipo de campo Tamaño de Almacenamiento


CHAR(n) n bytes
VARCHAR(n) n +1 bytes
TINYBLOB,
Longitud+1 bytes
TINYTEXT
BLOB, TEXT Longitud +2 bytes
MEDIUMBLOB,
Longitud +3 bytes
MEDIUMTEXT
LONGBLOB,
Longitud +4 bytes
LONGTEXT
ENUM('value1','valu 1 ó dos bytes dependiendo del número de
e2',...) valores
SET('value1','value2', 1, 2, 3, 4 ó 8 bytes, dependiendo del número
...) de valores
Diferencia de almacenamiento entre los tipos Char y VarChar

Almace VARCHAR( Almace


Valor CHAR(4)
namiento 4) namiento
'' '' 4 bytes " 1 byte
'ab' 'ab ' 4 bytes 'ab' 3 bytes
'abcd' 'abcd' 4 bytes 'abcd'
'abcdefgh' 'abcd' 4 bytes 'abcd' 5 bytes
Instrucción INSERT

INSERT inserta nuevas filas en una tabla existente.

INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]


[INTO] tbl_name
[PARTITION (partition_name [, partition_name] ...)]
[(col_name [, col_name] ...)]
{ {VALUES | VALUE} (value_list) [, (value_list)] ...
|
VALUES row_constructor_list

tbl_name es la tabla en la que se deben insertar las filas. Especifique las columnas para las que la

declaración proporciona valores de la siguiente manera:

Proporcione una lista entre paréntesis de nombres de columnas separados por comas después

del nombre de la tabla. En este caso, la lista VALUES, debe proporcionar un valor para cada

columna nombrada . Para el INSERT, el número de columnas en la tabla de origen debe coincidir

con el número de columnas que se insertarán.

Si no especifica una lista de nombres de columna para INSERT ... VALUES, los valores para

cada columna de la tabla deben ser proporcionados por la lista de datos en el orden de las columnas

de la tabla.

Una cláusula SET indica las columnas explícitamente por nombre, junto con el valor a

asignar a cada una.

Los valores de las columnas se pueden dar de varias formas:

Si el modo SQL estricto no está habilitado, cualquier columna a la que no se le haya dado un

valor explícitamente se establece en su valor predeterminado (explícito o implícito). Por ejemplo, si


especifica una lista de columnas que no nombra todas las columnas de la tabla, las columnas sin

nombre se establecen en sus valores predeterminados.

Si el modo SQL estricto está habilitado, una declaración INSERT genera un error si no especifica

un valor explícito para cada columna que no tiene un valor predeterminado.

Si tanto la lista de columnas como la lista VALUES están vacías, INSERT crea una fila con

cada columna establecida en su valor predeterminado:

INSERT INTO tbl_name () VALUES();

Utilice la palabra clave DEFAULT para establecer una columna explícitamente en su valor

predeterminado. Esto hace que sea más fácil escribir declaraciones INSERT que asignan valores a

todas las columnas excepto a unas pocas, porque te permite evitar escribir una lista

de VALUES incompleta que no incluye un valor para cada columna de la tabla. De lo contrario,

debes proporcionar la lista de nombres de columna correspondientes a cada valor de la

lista VALUES .

La conversión de tipo de una expresión expr que proporciona un valor de columna puede

ocurrir si el tipo de datos de la expresión no coincide con el tipo de datos de la columna. La

conversión de un valor dado puede resultar en diferentes valores insertados dependiendo del tipo de

columna. Por ejemplo, la inserción de la cadena '1999.0e-2' en una columna

INT, FLOAT, DECIMAL(10,6), o YEAR resultaría en inserciones de la columna de

valor 1999, 19.9921, 19.992100, o 1999, respectivamente. El valor almacenado en

las columnas INT y YEAR es 1999 porque la conversión de cadena a número solo considera la

parte inicial de la cadena como un número entero o año válido. Para las columnas FLOAT

y DECIMAL, la conversión de cadena a número considera la cadena completa como un valor

numérico válido.

Una expresión expr puede hacer referencia a cualquier columna que se estableció

anteriormente en una lista de valores. Por ejemplo, puede hacer esto porque el valor de col2 hace

referencia a col1, que se ha asignado previamente:

INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2);


Pero lo siguiente no es legal, porque el valor de col1 se refiere a col2, que se asigna después col1:
INSERT INTO tbl_name (col1,col2) VALUES(col2*2,15);
Se produce una excepción para las columnas que contienen valores AUTO_INCREMENT. Debido

a que los AUTO_INCREMENT valores se generan después de otras asignaciones de valor,

cualquier referencia a una columna AUTO_INCREMENT en la asignación devuelve un 0.

Insertar varios renglones


Las declaraciones que usan sintaxis VALUES pueden insertar varias filas. Para hacer esto, incluya

varias listas de valores de columna separados por comas, con listas encerradas entre paréntesis y

separadas por comas. Ejemplo:

INSERT INTO tbl_name (a,b,c)


VALUES(1,2,3), (4,5,6), (7,8,9);
Cada lista de valores debe contener exactamente tantos valores como se vayan a insertar por fila. La

siguiente declaración no es válida porque contiene una lista de nueve valores, en lugar de tres listas

de tres valores cada una:

INSERT INTO tbl_name (a,b,c) VALUES(1,2,3,4,5,6,7,8,9);


VALUE es un sinónimo de VALUES en este contexto. Ni implica nada sobre el número de listas de

valores, ni sobre el número de valores por lista. Se puede utilizar cualquiera de las dos, ya sea que

haya una lista de valores única o varias listas, e independientemente del número de valores por lista.

Las declaraciones que utilizan sintaxis VALUES ROW() también pueden insertar varias filas. En

este caso, cada lista de valores debe estar contenida dentro de un ROW()(constructor de filas), como
este:

INSERT INTO tbl_name (a,b,c)


VALUES ROW(1,2,3), ROW(4,5,6), ROW(7,8,9);

Establecer una columna numérica en un valor que se encuentra fuera del rango de la

columna. El valor se recorta al punto final más cercano del rango.

Asignar un valor como, por ejemplo, '10.34 a'a una columna numérica. El texto no numérico

final se elimina y se inserta la parte numérica restante. Si el valor de la cadena no tiene una parte

numérica inicial, la columna se establece en 0.


Sentencia SELECT
SELECTse utiliza para recuperar filas seleccionadas de una o más tablas y puede incluir

declaraciones UNION y subconsultas. Una declaración SELECT puede comenzar con una

cláusula WITH para definir expresiones de tabla comunes accesibles dentro de SELECT.

Las cláusulas de SELECTdeclaraciones más comúnmente utilizadas son las siguientes:

Cada select_expr indica una columna que deseas recuperar. Debe haber al menos

una select_expr.

table_references indica la tabla o tablas de las cuales vas a recuperar filas.

La cláusula WHERE, si se proporciona, indica la condición o condiciones que las filas

deben cumplir para ser seleccionadas. where_condition es una expresión que se evalúa como

verdadera para cada fila a seleccionar. La declaración selecciona todas las filas si no hay

ninguna cláusula WHERE.

En la expresión WHERE, podés usar cualquiera de las funciones y operadores que admite MySQL,

excepto las funciones agregadas de grupo o agrupación de datos.

SELECT también se puede utilizar para recuperar filas calculadas sin referencia a ninguna tabla.

Por ejemplo:

mysql> SELECT 1 + 1;
-> 2
Se le permite especificar DUAL como nombre de tabla ficticia en situaciones en las que no se hace

referencia a tablas:

mysql> SELECT 1 + 1 FROM DUAL;


-> 2
DUAL es puramente para la conveniencia de las personas que requieren que todas las declaraciones

SELECT deben tener FROM y posiblemente otras cláusulas. MySQL no requiere FROM DUAL si

no se hace referencia a tablas.

En general, las cláusulas utilizadas deben darse exactamente en el orden que se muestra en la

descripción dela sintaxis. Por ejemplo, una cláusula HAVING debe ir después de cualquier

cláusula GROUP BY y antes de cualquier cláusula ORDER BY. La cláusula INTO, si está presente,
puede aparecer en cualquier posición indicada por la descripción de la sintaxis, pero dentro de una

declaración determinada solo puede aparecer una vez, no en varias posiciones.

La lista de términos select_expr comprende la lista de selección que indica qué columnas

recuperar. Los términos especifican una columna o expresión o podés usar * o -shorthand:

Se puede utilizar una lista de selección que consta solo de un solo no calificado * como

forma abreviada para seleccionar todas las columnas de todas las tablas:

SELECT * FROM tabla1 INNER JOIN tabla2 ...

tbl_name.* se puede usar como una abreviatura calificada para seleccionar todas las

columnas de la tabla nombrada:

SELECT t1.*, t2.* FROM t1 INNER JOIN t2 ...

El uso de un elemento no calificado * con otros elementos de la lista de selección puede

producir un error de análisis. Para evitar este problema, utilice una tbl_name.* referencia calificada

SELECT AVG(score), t1.* FROM t1 ...


La siguiente lista proporciona información adicional sobre otras cláusulas SELECT:

A la select_expr se le puede dar un alias usando. El alias se utiliza como nombre de la

columna de la expresión y se puede utilizar en funciones o cláusulas.

Por ejemplo : AS alias_name GROUP BY ORDER BY HAVING

SELECT CONCAT(last_name,', ',first_name) AS full_name


FROM mytable ORDER BY full_name;
La palabra clave AS es opcional cuando se asigna un alias a un identificador select_expr. El

ejemplo anterior podría haberse escrito así:

SELECT CONCAT(last_name,', ',first_name) full_name


FROM mytable ORDER BY full_name;
Sin embargo, debido a que AS es opcional, puede ocurrir un problema sutíl si olvidás la coma entre

dos expresiones select_expr ya que MySQL interpreta la segunda como un nombre de alias. Por

ejemplo, en la siguiente declaración, columnb es interpretado por MySql como un nombre de alias:

SELECT columna columnb FROM mytable;


Por esta razón, es una buena práctica tener el hábito de usar AS explícitamente al especificar alias

de columna.
No está permitido hacer referencia a un alias de columna en una cláusula WHERE, porque es

posible que el valor de la columna aún no se haya determinado cuando se

ejecuta la cláusula WHERE .

La cláusula indica la tabla o tablas de las que recuperar filas. Si nombrás más de una tabla,

estás realizando una combinación. Para cada tabla especificada, opcionalmente podés especificar un

alias. FROM table_references

tbl_name [[AS] alias] [index_hint]


El uso de sugerencias de índice proporciona al optimizador información sobre cómo elegir índices

durante el procesamiento de consultas.

Puede hacer referencia a una tabla dentro de la base de datos predeterminada

como tbl_name o como db_name. tbl_name para especificar una base de datos explícitamente. Se

puede hacer referencia a una columna como col_name, tbl_name. col_name,

o db_name. tbl_name. col_name.

No es necesario especificar un prefijo tbl_name o db_name. tbl_name para una referencia de

columna a menos que la referencia sea ambigua.

Una referencia de tabla puede tener un alias usando AS . Estas declaraciones son

equivalentes: tbl_name AS alias_name tbl_name alias_name

SELECT t1.name, t2.salary FROM employee AS t1, info AS t2


WHERE t1.name = t2.name;
SELECT t1.name, t2.salary FROM employee t1, info t2
WHERE t1.name = t2.name;

Se puede hacer referencia a las columnas seleccionadas para la salida en cláusulas ORDER

BY y GROUP BY utilizando nombres de columna, alias de columna o posiciones de columna. Las

posiciones de las columnas son números enteros y comienzan con 1:

SELECT college, region, seed FROM tournament


ORDER BY region, seed;
SELECT college, region AS r, seed AS s FROM tournament
ORDER BY r, s;
SELECT college, region, seed FROM tournament
ORDER BY 2, 3;
Para ordenar en orden inverso, agregá la DESC palabra clave (descendente) al nombre de la

columna en la ORDER BY cláusula por la que está ordenando. El valor predeterminado es el orden

ascendente; esto se puede especificar explícitamente usando la palabra clave ASC.

Si ORDER BY ocurre dentro de una expresión de consulta entre paréntesis y también se aplica en la

consulta externa, los resultados no están definidos y pueden cambiar en una versión futura de

MySQL. El uso de posiciones de columna está en desuso porque la sintaxis se ha eliminado del

estándar SQL.

Antes de MySQL 8.0.13, MySQL admitía una extensión de sintaxis no estándar que

permitía designadores explícitos ASC o DESC para palabra clave GROUP BY columnas. MySQL

8.0.12 y versiones posteriores son compatibles ORDER BY con funciones de agrupación, por lo que

el uso de esta extensión ya no es necesario. Esto también significa que puede ordenar en una

columna o columnas arbitrarias al usar GROUP BY, así:

SELECT a, b, COUNT(c) AS t FROM test_table GROUP BY a,b ORDER BY a,t DESC;

MySQL extiende el uso de GROUP BY para permitir la selección de campos que no se

mencionan en la cláusula GROUP BY.

La HAVINGcláusula se aplica casi al final, justo antes de que los elementos se envíen al

cliente, sin optimización. ( LIMITse aplica después HAVING.)

El estándar SQL requiere que se HAVINGhaga referencia solo a columnas en la GROUP

BY cláusula o columnas utilizadas en funciones agregadas. Sin embargo, MySQL admite una

extensión para este comportamiento y permite HAVINGhacer referencia a columnas en

la SELECTlista y columnas en subconsultas externas también.

Si la HAVINGcláusula se refiere a una columna que es ambigua, aparece una advertencia. En la

siguiente declaración, col2es ambiguo porque se usa como alias y como nombre de columna:

SELECT COUNT(col1) AS col2 FROM t GROUP BY col2 HAVING col2 = 2;


Se da preferencia al comportamiento estándar de SQL, por lo que si HAVINGse usa un nombre de

columna tanto en GROUP BYcomo como una columna con alias en la lista de columnas de salida,

se da preferencia a la columna de la GROUP BYcolumna.


No lo utilice HAVINGpara elementos que deberían estar en la WHEREcláusula. Por

ejemplo, no escriba lo siguiente:

SELECT col_name FROM tbl_name HAVING col_name > 0;


Escribe esto en su lugar:

SELECT col_name FROM tbl_name WHERE col_name > 0;

La cláusula HAVING puede hacer referencia a funciones agregadas, que la cláusula

WHERE no puede procesar:

SELECT user, MAX(salary) FROM users


GROUP BY user HAVING MAX(salary) > 10;
(Esto no funcionaba en algunas versiones anteriores de MySQL).

MySQL permite nombres de columna duplicados. Es decir, puede haber más de

uno select_expr con el mismo nombre. Esta es una extensión de SQL estándar. Debido a que

MySQL también permite GROUP BY y HAVING hacer referencia a valores select_expr, esto puede

resultar en una ambigüedad:

SELECT 12 AS a, a FROM t GROUP BY a;


En esa declaración, ambas columnas tienen el nombre a. Para asegurarse de que se utilice la

columna correcta para la agrupación, utilice nombres diferentes para cada una select_expr.

MySQL resuelve referencias de columna o alias no calificadas en ORDER BYcláusulas

buscando en los valores select_expr, luego en las columnas de las tablas en la cláusula FROM. Para

las cláusulas GROUP BY o HAVING, busca la cláusula FROM antes de buscar en los valores
select_expr . (Para GROUP BY y HAVING, esto difiere del comportamiento anterior a MySQL 5.0

que usaba las mismas reglas que para ORDER BY).

La cláusula LIMIT se puede utilizar para restringir el número de filas devueltas por

la declaración SELECT. LIMIT toma uno o dos argumentos numéricos, que deben ser constantes

enteras no negativas, con estas excepciones:

Dentro de las declaraciones preparadas, los parámetros LIMIT se pueden especificar

mediante ? marcadores de posición.


Dentro de los programas almacenados, parámetros los LIMIT se pueden especificar

utilizando parámetros de rutina con valores enteros o variables locales.

Con dos argumentos, el primer argumento especifica el desplazamiento de la primera fila para
devolver y el segundo especifica el número máximo de filas para devolver. El desplazamiento de la

fila inicial es 0 (no 1):

SELECT * FROM tbl LIMIT 5,10; # Devuelve los renglones 6 a 15


Para recuperar todas las filas desde un cierto desplazamiento hasta el final del conjunto de

resultados, puede usar un número grande para el segundo parámetro. Esta declaración recupera

todas las filas desde la fila 96 hasta la última:

SELECT * FROM tbl LIMIT 95,18446744073709551615;


Con un argumento, el valor especifica el número de filas que se devolverán desde el principio del

conjunto de resultados:

SELECT * FROM tbl LIMIT 5; # Devuelve los primeros 5 renglones


En otras palabras, es equivalente a . LIMIT row_count LIMIT 0, row_count

Para declaraciones preparadas, puede utilizar marcadores de posición. Las siguientes declaraciones

devuelven una fila de la tbltabla:

SET @a=1;
PREPARE STMT FROM 'SELECT * FROM tbl LIMIT ?';
EXECUTE STMT USING @a;
Las siguientes declaraciones devuelven la segunda a la sexta filas de la tabla tbl:

SET @skip=1; SET @numrows=5;


PREPARE STMT FROM 'SELECT * FROM tbl LIMIT ?, ?';
EXECUTE STMT USING @skip, @numrows;
Para compatibilidad con PostgreSQL, MySQL también admite

la sintaxis. LIMIT row_count OFFSET offset

Si existe un LIMIT dentro de una expresión de consulta entre paréntesis y también se aplica en la

consulta externa, los resultados no están definidos y pueden cambiar en una versión futura de

MySQL.
Los modificadores ALLy DISTINCT especifican si se deben devolver filas duplicadas. ALL

(el valor predeterminado) especifica que se deben devolver todas las filas coincidentes, incluidos los

duplicados. DISTINCT especifica la eliminación de filas duplicadas del conjunto de resultados. Es


un error especificar ambos modificadores. DISTINCT ROW es sinónimo de DISTINCT.
Declaración UPDATE
UPDATE es una declaración que modifica filas en una tabla.

Una declaración UPDATE puede comenzar con una cláusula WITH para definir expresiones de

tabla comunes accesibles dentro de UPDATE.

Sintaxis de tabla única:

UPDATE [LOW_PRIORITY] [IGNORE] table_reference


SET assignment_list
[WHERE where_condition]
[ORDER BY ...]
[LIMIT row_count]

value:
{expr | DEFAULT}

Para la sintaxis de tabla única, la declaración UPDATE actualiza columnas de filas existentes en la

tabla nombrada con nuevos valores. La cláusula SET indica qué columnas modificar y los valores

que se les deben dar. Cada valor se puede dar como una expresión o la palabra clave DEFAULT

para establecer una columna explícitamente en su valor predeterminado. La cláusula WHERE, si se


proporciona, especifica las condiciones que identifican qué filas actualizar. Sin cláusula WHERE,

se actualizan todas las filas. Si ORDER BY se especifica la cláusula, las filas se actualizan en el

orden especificado. La cláusula LIMIT impone un límite al número de filas que se pueden

actualizar.

Para la sintaxis de varias tablas, UPDATE actualiza las filas de cada tabla nombrada y que

satisfacen las condiciones. Cada fila coincidente se actualiza una vez, incluso si coincide con las

condiciones varias veces.

Solo necesita el privilegio UPDATE para las columnas a las que se hace referencia en

un UPDATE archivo que están realmente actualizadas. Solo necesita el privilegio SELECT para

las columnas que se leen pero no se modifican.

La declaración UPDATE admite los siguientes modificadores:


Con el IGNOREmodificador, la declaración de actualización no se cancela incluso si

ocurren errores durante la actualización. Las filas para las que se producen conflictos de claves

duplicadas en un valor de clave único no se actualizan. En su lugar, las filas actualizadas a valores
que causarían errores de conversión de datos se actualizan a los valores válidos más cercanos.

Las declaraciones, incluidas las que tienen una ORDER BY cláusula, se marcan como inseguras

para la replicación basada en declaraciones. (Esto se debe a que el orden en el que se actualizan las

filas determina qué filas se ignoran).

Si accede a una columna de la tabla para actualizarla en una expresión, UPDATE usa el valor actual

de la columna. Por ejemplo, la siguiente declaración se establece col1 en uno más que su valor

actual:

UPDATE t1 SET col1 = col1 + 1;


La segunda asignación en la siguiente declaración establece col2 el valor actual (actualizado) col1,
no el col1 valor original . El resultado es eso col1 y col2 tienen el mismo valor. Este

comportamiento difiere del SQL estándar.

UPDATE t1 SET col1 = col1 + 1, col2 = col1;


Las asignaciones UPDATE de una sola tabla generalmente se evalúan de izquierda a derecha. Para

las actualizaciones de varias tablas, no hay garantía de que las asignaciones se lleven a cabo en un

orden en particular.

Si establece una columna en el valor que tiene actualmente, MySQL se da cuenta de esto y no la

actualiza.

Si actualiza una columna que se ha declarado NOT NULL estableciendo en NULL, se produce un

error si se habilita el modo SQL estricto; de lo contrario, la columna se establece en el valor

predeterminado implícito para el tipo de datos de la columna y se incrementa el recuento de

advertencias. El valor predeterminado implícito es 0para tipos numéricos, la cadena vacía ( '') para

tipos de cadena y el valor " cero " para tipos de fecha y hora.

Por ejemplo, si la tabla contiene 1 y 2 en la columna id y 1 se actualiza a 2 antes de que 2 se

actualizá a 3, se produce un error. Para evitar este problema, agregue una cláusula ORDER BY para

que las filas con valores id más grandes se actualicen antes que aquellas con valores más pequeños:
UPDATE t SET id = id + 1 ORDER BY id DESC;
También podés realizar operaciones UPDATE que abarquen varias tablas. Sin embargo, no puede

usar ORDER BY o LIMIT con una tabla múltiple UPDATE. La cláusula table_references enumera

las tablas involucradas en la combinación. Aquí hay un ejemplo:

UPDATE items,month SET items.price=month.price


WHERE items.id=month.id;
El ejemplo anterior muestra una combinación interna que usa el operador de coma, pero las

declaraciones UPDATE de varias tablas pueden usar cualquier tipo de combinación permitida en

declaraciones SELECT, como LEFT JOIN.


Declaración DELETE
DELETE es una declaración que elimina filas de una tabla.

Una declaración DELETE puede comenzar con una cláusula WITH para definir expresiones de

tabla comunes accesibles dentro de DELETE.

Sintaxis de tabla única

DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name [[AS] tbl_alias]


[PARTITION (partition_name [, partition_name] ...)]
[WHERE where_condition]
[ORDER BY ...]
[LIMIT row_count]
La declaración DELETE elimina filas tbl_name y devuelve el número de filas eliminadas. Para

verificar el número de filas eliminadas, llamá a la función ROW_COUNT().

Cláusulas principales

Las condiciones de la cláusula opcional WHERE identifican qué filas eliminar. Sin cláusula

WHERE , se eliminan todas las filas.

where_condition es una expresión que se evalúa como verdadera para cada fila que se va a

eliminar.

Si se especifica la cláusula ORDER BY, las filas se eliminan en el orden especificado. La cláusula

LIMIT impone un límite al número de filas que se pueden eliminar. Estas cláusulas se aplican a

eliminaciones de una sola tabla, pero no a eliminaciones de varias tablas.

Sintaxis de varias tablas

DELETE [LOW_PRIORITY] [QUICK] [IGNORE]


tbl_name[.*] [, tbl_name[.*]] ...
FROM table_references
[WHERE where_condition]
Privilegios

Necesita el privilegio DELETE de una tabla para eliminar filas de ella. Solo necesita el privilegio

SELECT para las columnas que solo se leen, como las que se mencionan en la cláusula WHERE.

Cuando no necesita saber el número de filas eliminadas, la declaración TRUNCATE TABLE es una

forma más rápida de vaciar una tabla que una declaración DELETE sin cláusula WHERE. A

diferencia de DELETE, TRUNCATE TABLE no se puede utilizar dentro de una transacción o si

tiene un bloqueo de la tabla.

Para asegurarte de que una declaración DELETE dada no tome demasiado tiempo,

la cláusula específica de MySQL para especifica el número máximo de filas que se eliminarán, la

candidadde número de filas para eliminar no debe ser mayor que el límite, repetí la declaración

hasta que el número de filas afectadas sea menor que el valor del total de cantidad de filas.

Columnas de incremento automático

Si eliminás la fila que contiene el valor máximo de una columna AUTO_INCREMENT, el valor no

se reutiliza para una tabla MyISAMo InnoDB. Si elimina todas las filas de la tabla con (sin

una cláusula where) , la secuencia comienza de nuevo para todos los motores de almacenamiento.

DELETE FROM tbl_nameWHERE autocommit InnoDB MyISAM InnoDB

Para las tablas MyISAM, puede especificar una columna AUTO_INCREMENT secundaria en una

clave de varias columnas. En este caso, la reutilización de los valores eliminados de la parte

superior de la secuencia se produce incluso para las tablas MyISAM .

Modificadores

La declaración DELETE admite los siguientes modificadores:

Si especifica el LOW_PRIORITY modificador, el servidor retrasa la ejecución del DELETE

hasta que ningún otro cliente esté leyendo de la tabla. Esto afecta solamente a los motores de

almacenamiento que utilizan solamente de bloqueo de nivel de tabla (tales

como MyISAM, MEMORY, y MERGE).


Para las tablas MyISAM, si usa el modificador QUICK, el motor de almacenamiento no

fusiona hojas de índice durante la eliminación, lo que puede acelerar algunos tipos de operaciones

de eliminación.

El modificador IGNORE hace que MySQL ignore errores ignorables durante el proceso de

eliminación de filas. (Los errores encontrados durante la etapa de análisis se procesan de la manera

habitual). Los errores que se ignoran debido al uso de IGNORE se devuelven como advertencias.

Orden de eliminación

Si la declaración DELETE incluye una cláusula ORDER BY, las filas se eliminan en el orden

especificado por la cláusula. Esto es útil principalmente junto con LIMIT. Por ejemplo, la siguiente

declaración busca filas que coincidan con la cláusula WHERE, las ordena timestamp_column y
elimina la primera (la más antigua):

DELETE FROM somelog WHERE user = 'jcole'


ORDER BY timestamp_column LIMIT 1;
ORDER BY también ayuda a eliminar filas en el orden requerido para evitar violaciones de la

integridad referencial.

Tablas InnoDB

Si estás eliminando muchas filas de una tabla grande, puede exceder el tamaño de la tabla de

bloqueo para una tabla InnoDB. Para evitar este problema, o simplemente para minimizar el tiempo
que la tabla permanece bloqueada, la siguiente estrategia (que no se usa DELETE en absoluto)

puede ser útil:

1. Seleccione las filas que no se eliminarán en una tabla vacía que tenga la misma estructura

que la tabla original:

INSERT INTO t_copy SELECT * FROM t WHERE ... ;


2. Utilice RENAME TABLE para mover atómicamente la tabla original fuera del camino y

cambiar el nombre de la copia al nombre original:

RENAME TABLE t TO t_old, t_copy TO t;


3. Desbloqueá la tabla original:

DROP TABLE t_old;


Ninguna otra sesión puede acceder a las tablas involucradas mientras se ejecuta RENAME TABLE,

por lo que la operación de cambio de nombre no está sujeta a problemas de concurrencia.

Tablas MyISAM

En las tablas MyISAM, las filas eliminadas se mantienen en una lista vinculada y las

operaciones INSERT posteriores reutilizan posiciones de filas antiguas. Para recuperar el espacio no

utilizado y reducir el tamaño de los archivos, use la instrucción OPTIMIZE TABLE o

la utilidad myisamchk para reorganizar las tablas. OPTIMIZE TABLE es más fácil de usar,

pero myisamchk es más rápido.

También podría gustarte