Professional Documents
Culture Documents
de referencia
de la sintaxis
de MySQL
En este apendice se incluyen las instrucciones y la sintaxis SQL utilizadas en
la version 4.0 de MySQL.
Para versiones posteriores es aconsejable consultar la documentacion
correspondiente a su distribucion o visitar el sitio de MySQL (www . mysql .
com).
La convencion utilizada a lo largo de 10s apendices es la siguiente:
Los corchetes ( [ ] ) indican un elemento opcional. Por ejemplo:
Tres puntos (...) indican que la opcion se puede repetir. Por ejemplo:
SELECT expresion, .. .
indica que la expresion se puede repetir (separada por una coma), como se
indica a continuacion: SELECT f 1, f2,f3.
ALTER
La sintaxis de ALTER es la siguiente:
ALTER [IGNORE] TABLE nombre-de-tabla especif icacion-alter [,
especificacion-alter- I ...
La sintaxis de e s p e c i f i c a c i 6 n -a 1t e r puede ser una de las siguien-
tes:
ADD [COLUMN] definition-create [FIRST I AFTER nombre-de-campo ]
ADD [COLUMN] (definition-create , definition-create, . . . )
ADD INDEX [nombre-de-indice] (nombre-de-campo-de-indice, ... )
ADD P R I W Y KEY (nombre-de-campo-de-indice, . . . )
ADD UNIQUE [nombre-de-indice] (nombre-de-indice, ) . ..
ADD FULLTEXT [nombre-de-indice] (nombre-de-indice, .) ..
ADD [CONSTRAINT simbolo] FOREIGN KEY nombre-de-indice
(nombre-de-indice, in direferencia-definicih]
ALTER [COLUMN] nombre-de-campo ( SET DEFAULT literal I DROP
DEFAULT 1
CHANGE [COLUMN] antiguo-nombre-de-campo definition-create [FIRST I
AFTER nombre-de-campo]
MODIFY [COLUMN] definition-create [FIRST I AFTER nombre-de-camp01
DROP [COLUMN] nombre-de-campo
DROP PRIMARY KEY
DROP INDEX nombre-de-indice
DISABLE KEYS
ENABLE KEYS
RENAME [TO] nuevo-nombre-de-tabla
ORDER BY nombre-de-campo
opcionesde-tabla
ALTER TABLE le permite cambiar la estructura de una tabla existente. Pue-
de aiiadir columnas ( ADD ), cambiar definiciones y nombres de columnas
( CHANGE), modificar definiciones de columnas sin cambiar el nombre (MODIFY),
eliminar columnas o indices ( DROP), cambiar el nombre de las tablas ( RENAME ),
ordenar datos ( ORDER ) asi como activar ( ENABLE ) y desactivar ( DISABLE)
indices.
Una extension MySQL que no sea ANSI es significa que ALTER TABLE
puede contener varios componentes (CHANGE, AND, etc.) en una instruccion.
Necesitara permiso ALTER, I N S E R T y CREATE en la tabla para utilizar
ALTER TABLE.
I G N O R E (extension MySQL no ANSI) hace que MySQL elimine registros
que puedan generar una clave principal o unica duplicada. Normalmente MySQL
cancela y ALTER falla.
FIRST y ADD...AFTER le permiten especificar donde se debe aiiadir un cam-
po a la definicion.
ANALYZE TABLE
ANALYZE TABLE nombre-de-tabla [, nombre-de-tabla.. .]
En tablas MyISAM y BDB, analiza y almacena la distribucion de claves de
las tablas especificadas. Bloquea las tablas con un bloqueo de lectura durante la
duracion de la operacion.
BACKUP TABLE
BACKUP TABLE nombre-de-tabla [ ,nombre-de-tabla.. .] TO
'nombre-de-ruta'
BEGIN
BEGIN
CHECK TABLE
CHECK TABLE nombre-tbl [, nombre-tbl-. .. ] [opcion [opcion.. .] 1
La opcion puede ser una de las siguientes:
CHANGED
EXTENDED
FAST
MEDIUM
QUICK
COMMIT
COMMIT
CREATE
La sintaxis de CREATE puede ser una de las siguientes:
CREATE DATABASE [IF NOT EXISTS ] nombre-de-base-de-datos
CREATE [UNIQUEIFULLTEXT] INDEX nombre-de-indice ON nombre-de-tabla
(nombre-de-campo [ (longitud) 1, . )..
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] nombre-de-tabla [ (crear -
.
definicion, . . ) 1
[opciones-de-tabla] [instruction-select]
DELETE
La sintaxis de D E L E T E puede ser una de las siguientes:
DELETE [LOW-PRIORITY I QUICK] FROM nombre-de-tabla [WHERE
clausula-where] [ORDER B Y ...
] [LIMIT filas]
DELETE [LOW-PRIORITY I QUICK] nombre-de-tabla [ * ] .
.
[ , nombre-de-tabla [ * ] ...
] FROM referencias de tablas [WHERE
clausula-where]
.
DELETE [LOW-PRIORITY I QUICK] FROM tabla [ *] , [tabla [ *] .
. . .I USING referencias de tabla [WHERE clausula-where]
La instruction D E L E T E borra registros de la tabla (o tablas) que cumplen la
clausula w h e r e (o todos 10s registros si no existe esta clausula).
La palabra clave LOW P R I O R I T Y hace que DELETE espere hasta que no
haya ningun cliente leyendo la tabla antes de procesarla.
La palabra clave Q U I C K hace que MySQL no combine hojas de indice duran-
te DELETE, lo que en ocasiones resulta mas rapido.
L I M I T determina el numero maximo de registros que se pueden eliminar.
La clausula O R D E R BY hace que MySQL borre registros en un determinado
orden (lo que resulta muy util con una clausula LIMIT).
DESC
DESC equivale a DESCRIBE
DESCRIBE
DESCRIBE nombre-de-tabla (nombre-de-campo I comodin)
DESCRIBE devuelve la definition de la tabla y 10s campos especificados
(igual que SHOW COLUMNS FROM n o m b r e de t a b l a ) .
Se puede utilizar un comodin como parte deinombre de archivo y puede ser
un signo % que equivale a un numero de caracteres o un guion bajo (-), que
equivale a un caracter.
La sintaxis de Do es la siguiente:
D O expresion, [expresion, . . .]
DO tiene el mismo efecto que SELECT, a exception de que no devuelve re-
sultados (lo que lo hace ligeramente mas rapido).
DROP
La sintaxis de DROP es la siguiente:
DROP DATABASE [IF EXISTS] nornbre-de-base-de-datos
DROP TABLE [IF EXISTS] nombre-de-tabla [ , nombre-de-tabla, ...]
[RESTRICT I CASCADE]
DROP INDEX nombre-de-indice ON nombre-de-tabla
EXPLAIN
EXPLAIN nornbre-de-tabla
EXPLAIN consults-select
GRANT
GRANT tipo-de-privilegio [(lista-de-campos)] [ , tipo-de-privilegio
[ (lista-de-campos) ]
. ..] ON Inombre-de-tabla I * I * . * I nombre-de-base-de-dates.*)
TO nombre-de-usuario
[IDENTIFIED BY [PASSWORD] 'contrasefia'] [ , nombre-de-usuario
[IDENTIFIED BY
'contrasefia'] ...I [REQUIRE NONE I [(SSLI X509)I [CIPHER cifrado
[AND1I
[ISSUER emisor [AND]] [SUBJECT asunto]] [WITH [GRANT OPTION I
MAX QUERIES PER HOUR # I MAX-UPDATES-PER-HOUR # I
MAXICONNECTIONSPER-HOUR #I1
INSERT
La sintaxis de I N S E RT puede ser una de las siguientes:
INSERT [LOW-PRIORITY I DELAYED] [IGNORE] [INTO] nombre-de-tabla
[ (nombre-de-campo, . . . ) 1 VALUES ( (expresion I
.
DEFAULT) , . . . ) , ( . . ) , . . .
INSERT [LOW-PRIORITY I DELAYED] [IGNORE] [INTO] nombre-de-tabla
.
[ (nombre-de-campo, . . . ) 1 SELECT . .
INSERT [LOW-PRIORITY I DELAYED] [IGNORE] [INTO] nombre-de-tabla
SET nombre-de-campo = (expresion I DEFAULT) , . . .
INSERT [LOW-PRIORITY] [IGNORE] [INTO] nombre-de-tabla [ (lista de
campos) ] SELECT . . .
INSERT aiiade nuevas filas a una tabla. Sin la lista inicial de campos, se
asume que 10s campos estan en el mismo orden que en la definicion, y que debe
haber un valor para cada uno de ellos.
Todas las columnas que no se definan explicitamente se configuran con su
valor predeterminado.
La palabra clave LOW PRIORITY hace que INSERT espere a que no haya
clientes leyendo la tabla antes de procesarla.
Con la palabra clave DELAY ED, MySQL libera el cliente per0 espera para
realizar la insercion.
I G N O R E hace que MySQL ignore las inserciones que resultan en la duplica-
cion de claves principales o exclusivas, en lugar de cancelarlas.
INSERT ..SELECT le permite insertar en una tabla desde filas existente de
una o varias tablas.
MySQL acepta cualquiera de las siguientes sintaxis para J O I N :
nombre-de-tabla, nombre-de-tabla
nombre-de-tabla [CROSS] JOIN nombre-de-tabla
nombre-de-tabla INNER JOIN condicion nombre-de-tabla
nombre-de-tabla STRAIGHT-JOIN nombre-de-tabla
nombre-de-tabla LEFT [OUTER] JOIN condicion nombre-de-tabla
nombre-de-tabla LEFT [OUTER] JOIN nombre-de-tabla
nombre-de-t abla NATURAL [LEFT [OUTER] ] JOIN nombre-de-tabla
nombre-de-tabla LEFT OUTER JOIN nombre-de-tabla ON
expresion condicional
nombre-deItabla RIGHT [OUTER] JOIN condicibn nombre-de-tabla
nombre-de-tabla RIGHT [OUTER] JOIN nombre-de-tabla
nombre-de-tabla NATURAL [RIGHT [OUTER] ] JOIN nombre-de-tabla
KILL
KILL id-subproceso
LOAD DATA lee datos de un archivo de texto y 10s aiiade a una tabla. Es una
forma mas rapida de aiiadir grandes volumenes de datos que por medio de
INSERT.
La palabra clave LOCAL indica que el archivo se encuentra en el equipo cliente;
en caso contrario, se asume que se encuentra en el servidor de bases de datos.
LOCAL no funciona si el servidor se ha iniciado con la opcion -local-
infi le=0 o si el cliente no ha podido admitirla.
Los archivos del servidor deben ser legibles para todos o encontrarse en el
directorio de bases de datos. Tambien necesitara el permiso FILE para utilizar
LOAD DATA en un archivo del servidor.
En el servidor, se supone que el archivo se encuentra en el directorio de bases
de datos de la base de datos actual si no se indica ninguna ruta. Si la ruta es
relativa, se asume que proviene del directorio de datos. Tambien se pueden utili-
zar rutas absolutas.
La palabra clave LOW PRIORITY hace que LOAD DATA espere hasta que
no haya ningun cliente leyendo la tabla antes de procesarla.
La palabra clave CONCURRENT permite que otros subprocesos puedan acce-
der a una tabla MyISAM a1 mismo tiempo que se ejecuta LOAD DATA (lo que
reducira la velocidad de LOAD DATA).
La palabra clave REPLACE hace que MySQL elimine y sustituya un registro
existente si tiene la misma clave principal o exclusiva que el registro que se va a
aiiadir. I G N O R E hace que MySQL continue con el siguiente registro.
Si se especifica una clausula FIELDS, a1 menos se necesita una de las si-
guientes opciones: TERMINATED BY, [OPT IONALLY 1 ENCLOSED BY y
ESCAPED BY. Si no se especifica ninguna clausula FIELDS, se asume que las
predeterminadas seran FIELDS TERMINATED BY ' \ t ENCLOSED BY
' ' ESCAPED BY ' \ \ ' . Estas clausulas especifican el caracter a1 final de un
campo (de forma predeterminada, una tabulacion), que rodean a1 campo (de for-
ma predeterminada nada) y el caracter de salida (de forma predeterminada, la
barra invertida). Debe prestar especial atencion cuando utilice rutas de Windows
para salir de la ruta correctamente.
Sin una clausula L I NE S, se asume que la predeterminada sera L I N E S
TERMINATED BY ' \ n ' . Especifica el caracter a1 final de un registro (de
forma predeterminada, una nueva linea). La opcion I G N O R E numero L I N E S
ignora una serie de lineas en la parte superior del archivo (lo que resulta muy util
cuando el archivo contiene un encabezado).
LOAD DATA INFILE es el complemento de SELECT...INTO INFILE.
LOCK TABLES
LOCK TABLES nombre-de-tabla [AS alias] {READ I [READ LOCAL] I
[LOW-PRIORITY]
WRITE) [ , nombre-de-tabla {READ I [LOW-PRIORITY] WRITE) . . . ]
La sintaxis de RE N AM E es la siguiente:
RENAME TABLE nombre-de-tabla T O nuevo-nombre-de-tabla
[ , nombre-de-tabla2 T O nuevo-nombre-de-tabla2 , . . I
REPAIR TABLE
REPAIR TABLE nombre-de-tabla [,nombre-de-tabla ... ] [EXTENDED]
[QUICK] [USE-FRM]
Repara una tabla MyISAM daiiada. Con la opcion QUICK, solamente se re-
para el arb01 de indices.
Con EXTENDED, el indice se vuelve a crear fila a fila. Con U S E R FRM, el
indice se repara en funcibn del archivo de datos (para cuando falte elindice o
este totalmente dafiado).
REPLACE
La sintaxis de REPLACE puede ser una de las siguientes:
REPLACE [LOW-PRIORITY I DELAYED] [INTO] nombre-de-tabla
..
[ (nombre-de-campo,. . . ) 1 VALUES (expresion,. . . ) , ( . . . ) , .
REPLACE [LOW-PRIORITY I DELAYED] [INTO] nombre-de-tabla
.
[ (nombre-de-campo, . . ) 1 SELECT ...
REPLACE [LOW-PRIORITY I DELAYED] [INTO] nombre-de-tabla SET
nombre-de-campo =expresion, nombre-de-campo =expresion, ...
REPLACE es exactamente igual que INSERT, a excepcion de que cuando
MySQL encuentra un registro con una clave principal o exclusiva que ya existe,
la elimina y la reemplaza.
RESET
RESET opcion-reset [,option-reset] ...
o p c i o n-r e s e t puede ser una de las siguientes:
MASTER
QUERY CACHE
SLAVE
RESTORE TABLE
RESTORE TABLE nombre-de-tabla [,nombre-de-tabla . . . I FROM 'ruta'
Recupera una tabla de la que se ha creado una copia de seguridad con BACKUP
TABLE.
No sobrescribe las tablas existentes.
REVOKE
REVOKE tipo-de-privilegio [(lista-de-campos)] [,tipo-de-privilegio
[ (lista-de-campos) 1
... ] ON {nombre-de-tabla I * I * . * I nombre-de-base-de-dates.*)
FROM nombre-de-usuario
[ , nombre-de-usuario . ] ..
Elimina 10s privilegios concedidos previamente a 10s usuarios especificados.
t ipo -de-privi legio puede ser cualquiera de 10s privilegios enumerados
para GRANT.
ROLLBACK
ROLLBACK
SELECT
La sintaxis de SELECT es la siguiente:
SELECT [STRAIGHT-JOIN] [SQL-SMALL-RESULT] [SQL-BIG-RESULT]
[SQL-BUFFER-RESULT] [SQL-CACHE I SQL-NO-CACHE]
[SQL-CALC-FOUND-ROWS] [HIGH-PRIORITY] [DISTINCT I
.
DISTINCTROW I ALL] expresion, . . [INTO (OUTFILE I
DUMPFILE) 'nombre-de-archivo' opciones-de-exportation]
[FROM nombres-de-tabla
[WHERE clausula-where] [GROUP BY {entero-sin-firma I
nombre-de-campo I formula) [ASC I DESC], . . . [HAVING
definicionwhere] [ORDER BY (entero-sin-firma I
nombre-de-campo I formula) [ASC I DESC], . . . ] [LIMIT
[desplazamiento,] filas] [PROCEDURE nombre-procedimiento] [FOR
UPDATE I LOCK IN SHARE MODE] ]
La clausula WHERE esta formada por condiciones (que pueden contener fun-
ciones) que debe cumplir una fila para poder ser devuelta:
SELECT team-name FROM results WHERE points > 10
SQL CALC FOUND ROWS hace que MySQL calcule el numero de filas que
se tendrian que-haber de-vuelto si no hubiera una c l ~ u s u l aLIMIT. Esta cifra se
puede obtener con ayuda de la funcion SELECT FOUND ROWS ( ) .
SQL CACHE hace que MySQL almacene el resultado en la cachC de consul-
tas y, SQL-NO-CACHE, que no lo haga. Se trata de dos extensiones MySQL no
ANSI.
STRAIGHT J O I N (una extension MySQL no ANSI) hace que el optimizador
combine las tablas en el orden en el que aparecen en la clausula FROM, lo que
puede aumentar la velocidad de las consultas si las tablas se combinan de una
forma que no sea optima (utilice EXPLAIN para comprobarlo).
SELECT...INTO OUT FILE ' nombre de archivo" escribe 10s resul-
tados en un nuevo archivo (que todo el mundo plede leer) en el servidor. Nece-
sita el permiso FILE para utilizarlo. Es el complemento de LOAD DATA INFILE
y utiliza las mismas opciones.
A1 utilizar I N T O DUMPFILE, MySQL escribe una fila en el archivo, sin
columnas o terminaciones de linea y sin conversiones de escape.
Con tablas InnoDB y BDB, la clausula FOR UPDATE escribe bloqueos en las
filas.
SET
SET [GLOBAL I SESSION] nombre-de-variable =expresion, [[GLOBAL I
SESSION I
LOCAL ] nombre-de-variable =expresion ...I
m
SET TRANSACTION
SET [GLOBAL I SESSION] TRANSACTION ISOLATION LEVEL { READ UNCOMMITTED
I READ COMMITTED I REPEATABLE READ I SERIALIZABLE )
Define el nivel de aislamiento de transacciones. De forma predeterminada,
solamente se aplica a la siguiente transaccion, a menos que se utilicen las pala-
bras clave S E S S I O N o GLOBAL (que determinan el nivel de todas las transac-
ciones en la conexion actual o en todas las transacciones de las nuevas
conexiones).
SHOW
La sintaxis de SHOW puede ser una de las siguientes:
SHOW DATABASES [LIKE expresion]
SHOW [OPEN] TABLES [FROM nombre-de-base-de-datos] [LIKE expresion]
SHOW [FULL] COLUMNS FROM nombre-de-tabla [FROM
nombre-de-base-de-datos] [LIKE expresion]
SHOW INDEX FROM nombre-de-tabla [FROM nombre-de-base-de-datos]
SHOW TABLE STATUS [FROM nombre-de-base-de-datos] [LIKE expresion]
SHOW STATUS [LIKE expresion]
SHOW VARIABLES [LIKE expresion]
SHOW LOGS
SHOW [FULL] PROCESSLIST
SHOW GRANTS FOR usuario
SHOW CREATE TABLE nombre-de-tabla
SHOW MASTER STATUS
SHOW MASTER LOGS
SHOW SLAVE STATUS
TRUNCATE
TRUNCATE TABLE nombre-de-tabla
UNLOCK TABLES
UNLOCK TABLES
UPDATE
UPDATE [LOW-PRIORITY] [IGNORE] nombre-de-tabla SET
nombre-de-campol=expresionl [, nombre-de-campo2=expresibn2, ...I
[WHERE cldusula-where] [LIMIT #]
USE
USE nombre-de-base-de-datos