PHP + Mysql Desde 0
PHP + Mysql Desde 0
PHP + Mysql Desde 0
RU
1I
+
RedUSERS
.
TITULO: PHP + l\IlySQL desde cero
AUTOR: Francisco l\Ilinera
COLECCIÓN: Desde Cero
FORlviATO: 19 x 15 cm
PÁGINAS: 192
Copyright © MMXIV. Es una publicación de Fox Andina en coedición con DÁLAGA S.A. Hecho el depósito que
marca la ley 11723. Todos los derechos reservados, Esta publicación no puede ser reproducida ni en todo
ni en parte, por ningún medio actual o futuro sin el permiso previo y por escrito de Fox Andina S.A. Su infrac-
ción está penada por las leyes 11723 y 25446. La editorial no asume responsabilidad alguna por cualquier
consecuencia derivada de la fabricación, funcionamiento y/o utilización de los servicios y productos que se
describen y/o analizan. Todas las marcas mencionadas en este libro son propiedad exclusiva de sus respec-
tivos dueños. Impreso en Argentina. Libro de edición argentina. Primera impresión realizada en sevagraf,
Costa Rica 5226, Grand Bourg, Malvinas Argentinas, Pcia. de Buenos Aires en VIl, MMXIV.
ISBN 978-987-1949-66-3
Minera, Francisco
PHP + IvlySQL desde cero.
la ed. - Ciudad Autónoma de Buenos Aires: Fox Andina;. Buenos Aires: Dalasa,
w • 2014.
ISBN 978-987-1949-66-3
1. Informática, I. Título
CDD 005.3
» www.redusers .com
PHP T MYSQL DESDE CERO 3
Prólogo al contenido
Tanto el lenguaje de programación como el gestor de bases
de datos están posicionados en el mercado desde hace largo
tiempo. Podemos analizar algunos hechos respecto a ellos.
En relación con las modificaciones, han sido positivas para
los desarrolladores. Las nuevas versiones tanto de PHP como
de MySQL han sido aceptadas de muy buena manera, y las
mejoras incluidas han dado respuestas a los pedidos de la
gran comunidad de usuarios.
Otro punto es el continuo crecimiento del número de pro-
gramadores que optan por estas herramientas. Por un lado,
están los que, sin experiencia previa, encuentran que pueden
comenzar a desarrollar aplicaciones funcionales, incluso du-
rante el proceso de aprendizaje. Por otro lado, quienes pro-
vienen de otros lenguajes o tecnologías de desarrollo ven que
tanto PHP COlTIO MySQL les permiten elaborar soluciones rápi-
das, estables, de bajo costo y fácilmente actualizables.
Una de las virtudes del lenguaje (su facilidad de aprendiza-
je) deriva en algo que podría verse como negativo: hay muchas
personas que programan en PHP. Si bien la competencia es
algo que beneficia tanto a empleados como a empleadores, al
haber tanta oferta, las condiciones de los empleadores tienen
mayor preponderancia. Desde un lado positivo, la competencia
genera que los programadores se esfuercen por ser mejores, y
esto a su vez deriva en mejores condiciones laborales.
Un último punto está relacionado con la visión de algunas
empresas para con el lenguaje, que, ya sea por publicidad,
falta de conocimiento o soporte técnico, prefieren apostar a
alternativas como .Net o Java. Esperamos que, luego de leer
este manual, puedan poner en práctica sus conocimientos
y sacar sus propias conclusiones.
www.redusers.com «
4 [o;j3;;;3 PRELIMINARES
Ellibro de un vistazo
Conocer a fondo todas las características y posibilidades que un lenguaje
de programación como PHP nos brinda es una tarea qtle requiere paciencia y
aplicación por parte del desarrollador. A lo largo de los siguientes capitulos
íntentaremos ír asimilando, poco a poco, las técnicas y los métodos necesa-
rios para sacar provecho de la potencia del lenguaje.
» www.redusers .com
PHP + MYSQL DESDE CERO t'l'id.fi 5
A lo largo de este manual, podrá encontrar una serie de recuadros que le brindarán información
complementaria: curiosidades, tIl1COS, ideas y consejos sobre los temas tratados. Para que pueda
distinguirlos
~ en forma más sencilla, cada recuadro está identificado con diferentes iconos:
,
www.reduaers.com «
6 PRELIMINARES
Contenido dellibro
Prólogo 3 Licencia de oso 41
El libro de un vistazo...................................... 4 Resumen 41
Introducción 10
lVlySQL
PHP Tipos de tablas 44
Características de PHP 12 IS •.l\.l\'I 4·4
Resumen 23 Numértcos 53
Referencia de funciones 59
Typeff) [VARCHAR •
LengthNalues1 VARCHAR
Bases de datos Collation
TINYINT
TeXT
Qué es una base de datos 26 Attributes DATE
SMALLINT
Arquitectura de bases de datos 26 Null MEDIUMINT
Default2 INT
Modelo de datos relacional. 27 BIGINT
Extra FLOAT
Base de datos relacional. 27 DOUBLE
DECIMAL
Tipos de relaciones entre. tablas 34 DATETIME
TlMESTA'oAP
Gestor de base de datos:MySQL 40
Por qué iVlySQL 40
- TIME
Obtener iVlySQL 40
» www.redusers .com
PHP + MYSQL DESDE CERO 7
www.redusers.com «
8 ttf1#¡f, PRELIMINARES
*
Manejo de errores
Administración de bases de datos
El rol del administrador
O~"IB
'ii C:\windo\'ls\system32\cmd.exe
» www.redusers .com
E:\-:\l.""ESTROSITIO PODR.\ ACCEDER A L-:XAPRE''IE'''DIGITAL DE CADA LIBRO y TA.,mIÉ~
OBTE:\""ER,DE~IA."""ER~GR~ TLTIA, L-:XCAPÍTL"LOE:\\"ERSIÓ:\""PDF, EL SL,)L~O CO~IPLETO
E ThLÁGE:\""ES_-L'IPLLID_o\.SDET.o\.PAy CO:\lR~T.o\.PA.
RedUSERS • redusers.com
Nuestros libros incluyen guías visuales, explicaciones paso a paso, recuadros
complementarios, ejercicios y todos los elementos necesarios para asegurar
un aprendizaje exitoso.
»OCA
www~ r .eDC
10 PRELIMINARES
Introducción
El objetivo principal de este libro es introducir al lector
en el desarrollo de aplicaciones web, tomando como base dos
de las herramientas más populares de la actualidad: el lenguaje
de programación PHP y la base de datos relacional MySQL.
Una enorme cantidad de sitios web utilizan estas tecnolo-
gías, algo muy motivante para aquellos estudiantes de siste-
mas o simplemente aficionados que quieran insertarse en el
mercado y que necesiten hacerlo a través de tecnologías pro-
badamente aceptadas.
PHP y l\1ySQL brindan una alternativa más a quienes quie-
ren desarrollar soluciones altamente sofisticadas orientadas a
todo tipo de emprendimientos, desde los más simples a los más
complejos. Este manual tiene la finalidad de dar algunas res-
puestas que a su vez lleven a nuevas preguntas, es decir, dispa-
radores que obliguen al lector a continuar permanentemente la
búsqueda de nuevos niveles de especialización.
Los requisitos para el lector son mínimos: tener experiencia
en el uso de algún sistema operativo y una idea básica acerca
del funcionamiento de la arquitectura cliente/servidor; esto im-
plica realizar una petición a un servidor web a través de un na-
vegador y obtener una respuesta adecuada.
En definitiva, tanto PHP como l\1ySQL están transitando un ca-
mino iniciado hace ya mucho tiempo, y los resultados son real-
mente beneficiosos para todos los que de alguna manera están
relacionados con el mundo del desarrollo de aplicaciones web.
» www.redusers .com
PHP
Características de PHP
PHP, acrónimo de PHP Hypertext Preprocessor ,es un lenguaje de
programación que se utiliza principalmente para el desarrollo de sitios
web, pero que para muchos es lln lenguaje de propósito general, y el uso
que se le dé dependerá en parte de lo que necesite el programador.
Entre las características que hacen de PHP un lenguaje poplllar y muy
poderoso para desarrollar aplicaciones, podemos citar las siguientes:
• A ~.1H ..........
. "... _t1Ibo.· ~II ,,...,
......
","","-l .....
,t..........,,.,
'., .....I...~.p'''''''''-... 1'~"""'~"""."'P"C'",""""'~~",ot.. tWP' '''''t"WC''.''N
..u~" .,IIU_..-dIM. ....:. -ni
» www.redusers .com
PHP + MYSQL DESDE CERO 13
PHP5
PHP 5 experimentó cambios importantes que revolucionaron el lenguaje.
La primera versión de PHP 5 se liberó en junio de 2003, pero la primera con-
siderada estable es la de julio de 2004. En 2014, contamos con la versión PHP
5.5.10, de la que a continuación destacaremos algunas de sus características.
Generalídades
• Podemos ver las últimas actualizaciones en:
http://php.net/ChangeLog-5.php#5.5.1 O.
• En cuanto a la programación orientada a objetos, PHP ofrece notables
mejoras que lo hacen una alternativa totalmente competente en este
aspecto en comparación a otros lenguajes con historia en este campo.
• Mejoras en el soporte de XML (gestión de información):
https://,viki.php.net/internals/,vindows/libs/libxmI2 .
• Mejoras en el manejo de LDAP (manejo de directorios):
https://wiki.php.net/internals/,vindows/libs/ldap .
• Mejoras sobre el motor Zend (desempeño del lenguaje):
http://zend.comlen/company/community/php .
www.reduaers.com «
14 [!:':¡ ~i¡;3
1.PHP
SQLite
SQLite es una libreri a desarrollada en e que implementa un motor
de base de datos accesible por varios lenguajes: PHP, PYTHON, e, etc.
No permite que múltiples usuarios ingresen simultáneamente en modo
escritura a la base de datos; si esto sucede, el mecanismo de bloqueo la in-
moviliza por completo. Por eso, esta librería está especialmente indicada
cuando se requiera una gran rapidez en las consultas y sea suficiente qlle
un único usuario realice modificaciones. Es entre dos y tres veces más rápida
que bases de datos como MySQL o PostgreSQL, ya que no es un servidor, sino
una base de datos de escritorio, por lo que el acceso a los datos es más direc-
to, entre otras razones. Brinda soporte para un máximo de 2 terabytes de
datos. Además, es un software libre, y podremos descargarlo y obtener más
información en su sitio oficial: www.hwaci.com/sw/sqlíte.
- e n UIlIIU
_ ..-
fII&I ............. .., ....... .c~ .. ~....".,.-
mozilla
~ Senlle\J
--- I!:!b ..........- ....... __ .
MySQLi
IvlySQLi(con i de ímproved, mejorado) es una extensión que permite
acceder a las funcionalidades provistas por MySQL a partir de la versión
4.1.2. Se ha probado que ofrece mayor velocidad, en algunas operaciones
es hasta cuarenta veces más rápida que la extensión MySQL anterior.
» www.redusers .com
PHP T MYSQL DESDE CERO [!JOOj3;fi 15
www.redusers.com «
16 ttfj3¡fi 1.PHP
Extensiones en PHP
Cuando programamos en un lenguaje, no solo en PHP, nos valemos de fun-
ciones o procedimientos, ya sea para resolver problemas o modular el código
y hacerlo más legible o reutilizarlo sin escribir lo mismo más de una vez.
» www.redusers .com
PHP + MYSQL DESDE CERO 17
Ventaja de trabajar
con extensiones/bibliotecas
Solo cargamos las bibliotecas cuando las usamos, es decir, no hay so-
brecarga de trabajo innecesaria. PHP ya tiene demasiadas funciones incor-
poradas, y sería poco recomendable iniciar el motor para soportar cientos
de funciones de las cuales probablemente necesitemos solo algunas.
Una de las equivocaciones frecuentes a la hora de publicar archivos PHP en un servidor con un
sistema operativo diferente del nuestro es la de escribir las rutas a archivos o directorios de ma-
nera incorrecta, Los sistemas Unix compatibles usan el símbolo / (barra hacia la derecha) para
acceder a subdirectorios, y los sistemas Windows usan el símbolo (barra hacia la izquierda),
www.redusers.com «
18 ttf9#¡f3 1.PHP
Además, al añadir una biblioteca no hace falta reinstalar PHP, solo habi-
litar desde el archivo php.ini lo que necesitamos. Esto es la modularidad.
Extensiones incorporadas
PHP contiene, sin necesidad de ningún tipo de instalación ni habilita-
ción adicional, entre otras, las siguientes funciones:
• Manejo de matrices.
• Funciones matemáticas.
• BCMath.
• Manejo de clases/objectos.
• Manejo de variables de tipo carácter.
• Tratamiento de fechalhora.
• Acceso directo a entrada/salida.
• Funciones de directorio.
• Gestión de errores y registros.
• Funciones de sistema de archivos.
• Utilización del protocolo FTP.
• Utilización del protocolo HTTP.
• Funciones de correo.
• Funciones de red.
• Ejecución de programas.
» www.redusers .com
PHP + MYSQL DESDE CERO 19
• Manejo de sesiones.
• Funciones de secuencia.
• Funciones de cadenas.
• Funciones URL.
• Manejo de variables.
<?PHP
// funcion PHPülfo
phpínfot);
?>
Bases de datos
En este libro lo principal es la explicación del manejo de bases de datos.
El lenguaje PHP soporta, entre otras, el manejo de las siguientes bases:
• clBase
• Informix
• InterBase
• :tvlSSQL Server
• IvlySQL
www.redusers.com «
20 ttfj#;f3 1.PHP
• msql
• Oracle
• PostgreSQL
• Sybase
» www.reduserscom
PHP .,. MYSQL DESDE CERO 21
,
HOI"'" I Oll-Etlginps: Rankin9 I Systemf¡
...»XL Dw=r $*
• ""9 QI4
H_ M_SQl._X 0I1Ide X
0eK~ ()IN!;
wó<+r _IIOOM'.
DB _ 1 Roo!. 1
[no- _. 1205.111 _. 1491.10
R
11
"''''*''J
l'cnd .......
~
(h.n ~
Webse\. ""'"' ~COftllql __
Oevelot>tr Hlaoson
Jn.ltj~re..t_H ._
uc:ono. _Cltl 11
- ..-
lmptunCiMobon C••
tono..og·
Portabilidad
PHP es un lenguaje multiplataforma, lo que significa que está preparado
para trabajar sobre distintos sistemas operativos. Pero la portabilidad in-
cide también en el11ec110de que no es necesario realizar grandes cambios
en el código fuente de una aplicación escrita en PHP en el momento
de trasladarla de una plataforma a otra. Por ejemplo, si 10 deseamos,
se puede desarrollar una aplicación en Windows o MAC, pero luego subir
el mismo código a un servidor que esté corriendo Linux.
La portabilidad de PHP es, sin duda, un punto fuerte frente a lenguajes
como ASP/ASP.NET, que necesitan de componentes adicionales para correr
en algunas plataformas. PHP funciona en una gran cantidad de sistemas ope-
rativos y sin necesidad de un componente adicional que debamos comprar.
www.redusers.com «
22 1.PHP
Por lo general, se logra un mayor entendimiento del lenguaje cuando se lee código es-
crito por otras personas. Un mismo problema puede resolverse de muchas maneras,
y no quedarse solo con un punto de vista ayuda a abrir nuestra mente e incorporar
nuevas formas de encarar la escritura de un código.
» www.redusers .com
PHP + MYSQL DESDE CERO 23
• Ruta a archivos/directorios.
• Bibliotecas que solo funcionan en algunos sistemas, por ejemplo:
- Funciones W32api (solo para plataformas Windows de 32 bits).
- Funciones para el manejo de impresoras (solo para Windows 9.x,
ME, NI4 Y2000).
- Las funciones COM para Windows.
- Funciones de acceso directo a E/S
(no disponibles para sistemas Windows).
- Funciones GMP (que permiten trabajar con enteros de longitud variable;
no disponibles para sistemas Windows).
- Funciones para el control de procesos
(no disponibles para sistemas Windows).
- Funciones FM1 (notifican cambios en archivos y directorios;
no disponibles para sistemas Windows).
- Funciones POSIX (no disponibles para sistemas Windows).
- Funciones para Ncurses (no disponibles para sistemas Windows).
En este capítulo hemos realizado una reseña de las principales virtudes del lenguaje
de programación PHP: qué hace, para qué sirve y Sl¡S extensiones principales para
bases de datos. En definitiva, un punto de partida para conocer 10 que el lenguaje nos
tiene preparado para el manejo de bases de datos.
www.redusers.com «
24 1.PHP
Actividades
TEST DE AUTOE\' AL{jACIÓ~
4 ¿En qué versión de PHP se incorporó la extensión MySQLi? ¿Para qué sirve?
6 ¿Qué es SQLite?
7 ¿PHP puede trabajar con múltiples servidores web o solo con Apache?
EJERCICIOS PRÁCTICOS
» www.redusers .com
ases atos
Así como en la POO la abstracción de información implica obtener del mundo real da-
tos útiles, en este caso, la abstracción se utiliza para el almacenamiento de registros.
Por ejemplo, de un par de zapatillas podemos determinar: marca, tipo, material, tamaño, etc.
» www.redusers .com
PHP -e- MYSQL DESDE CERO 27
• Externo: aqui se define qué partes de la base de datos podrán ser vistas
y cuáles serán ocultas a qué usuarios. Es el nivel de mayor abstracción.
DE DATOS
Nos centraremos en el modelo que vamos
RELACIONADOS
a utilizar para confeccionar bases de datos:
r
Base de datos
relacional
El modelo relacional es, sin dudas, el más popular desde hace tiem-
po. Tomó notoriedad en 1970 y fue creado por Edgar Frank Codd .
Con él se imponen conceptos tales como tabla (arreglo bidimensional),
fila y columna. Los datos se recuperan a través de lenguajes de consul-
ta (el más popular es SQL, pero existen otros) que mantienen la com-
patibilidad aun entre sistemas gestores de bases de datos de distintas
-,. .
compamas o sistemas operativos.
www.redusers.com «
28 ttfj#;f3 2. BASES DE DATOS
Tabla
Una tabla es una colección de una o más columnas y cero o más filas.
Puede entenderse como una estructura de datos simple que se asemeja
a una matriz de dos niveles: el primero podría representar el número
de fila, y el segundo, el número de columna. Para acceder a un valor de
» www.reduserscom
PHP .,. MYSQL DESDE CERO 29
esta matriz, debemos indicar alguno de esos datos. Como se dijo, una
tabla nos permite organizar los datos en filas (también llamadas tuplas o
registros) y columnas (atributos o campos). Cada una de las filas (los datos
contenidos en ellas) se diferencia de las otras en algún dato almacenado.
Cada columna dentro de una fila es el valor de un atributo de esa fila.
Continuando con nuestro ejemplo, podemos decir que factura es nues-
tra tabla, que, al ser diseñada y almacenada, la nombraremos como enti-
dad. Veamos cómo quedaria la tabla fachIra en una vista de diseño:
Columnas
I
I O 1 2 3 I
O
Filas 1
2 1I
U
Columna2 Número
Columna3 Fecha
www.redusers.com «
30 2. BASES DE DATOS
Atributo
Un atributo define y diferencia una entidad de otra. Los atributos
pueden verse como características de las entidades. Veamos un ejemplo:
un perro puede tener un nombre, un dueño, un color de pelo, una edad,
una comida preferida y demás.
Todos estos son atributos de un perro (entidad). Nótese que no defi-
nimos ningún valor particular para estas características, el atributo es
el nombre del perro y no un perro. Veamos algunos atributos que pode-
mos definir para la entidad factura.
Campo/Atributo Descripción
-
Catezoría
Total
Relación
Una relación es una vinculación entre ideas, un modo de asociar
entidades/tablas para lograr el objetivo que tienen en común. Es decir
que mediante esa vinculación es posible realizar una función.
De manera más concreta, es posible considerar que una relación
es una asociación entre entidades. Por ejemplo, podemos decir que
la entidad factura tiene una relación con la entidad productos (de
donde se obtienen los detalles de 10 que vamos a registrar).
» www.redusers .com
PHP .,. MYSQL DESDE CERO 31
Claves primarias
Para diferenciar una entidad de otra, debemos remitirnos a sus atribu-
tos y, para distinguir una fila de otra dentro de una tabla, nos guiamos por
la clave primaria. Una clave primaria ofrece la particularidad de no tener
valores repetidos. Para decidir cuál de todos los atributos formarán parte
de la clave primaria, debemos buscar uno que cumpla con el requisito
anterior, y, si no existe, deberemos crear una clave primaria artificial.
Veamos ejemplos de cada situación.
En la tabla libros, tenemos la siguiente estructura.
Nombre
Cantidad _páginas
Editorial
ISBJ\
Autor
En este ejemplo, al repasar los atributos uno por uno, notaremos qlIe solo
hay uno que no va a repetirse, y es ISBN. Podemos tomarlo como clave prima-
ria: no habrá dos filas con el mismo ISBN, no habrá dos libros con el mismo
ISBN. Una clave primaria puede estar formada por más de un atributo,
en este caso se dice que es una clave compuesta. ¿Podríamos tomar
como clave primaria a ISBN y cualquier otro atributo, como por ejemplo
Editorial? Sí, se podría, pero no se debería por la estabilidad de la in-
formación que almacenaremos.
Nada nos impide pasar por alto la clave ISBN y crear otra, que podria lla-
marse codigo_libro. En este caso codigo_libro no significa nada, no tiene ningu-
na implicancia para lo que es un libro: es solo un atributo con una restricción
básica que será el hecho de no poder repetirse. Se trata de respetar ciertas
técnicas de diseño de bases de datos y, a la vez, tener en cuenta lo que
www.redusers.com «
ttfj#;f3 2. BASES DE DATOS
nuestro sistema necesita; las decisiones finales corren por cuenta de las
personas que se encarguen de ello. Veamos otro caso en el cual tene-
mos la tabla alumnos, cuya estructura inicial es la siguiente:
Nombre alumno
Dirección
Curso
Colegio
Nacionalidad
En este ejemplo no hay ningún atributo que no pueda llegar a repetirse en los
distintos alumnos. La solución es crear una clave y asignarla a cada alumno.
Podríamos llamarla codigo_alumno y, al generarla, nos aseguramos de que no
pueda tomar valores repetidos. Repasemos el ejemplo de la tabla factura:
Campo/Atributo Descripción
Categoría
Total
» www.reduserscom
PHP + MYSQL DESDE CERO 33
,
Indices
Un índice es una estructura de datos en donde se almacena información
adicional acerca de una columna (una columna indexada). Cuando se en-
cuentra un índice en una columna, el gestor de base de datos lo usará para
no recorrer todos los registros de una tabla.
Vistas
Existen ocasiones en las que no nos interesa que todos los usuarios de
una base de datos puedan ver todos los datos de la base (ya sea por temas
de seguridad, orden o, simplemente, para mostrar a cada usuario lo que
estrictamente precise para realizar su trabajo). Para esto existen las llama-
das vistas, que nos permiten recortar una tabla y restringir el acceso a
ella. Por ejemplo, si tomamos en cuenta la siguiente tabla:
www.redusers.com «
34 ttfj3¡fi 2. BASES DE DATOS
Tabla Empleados
Vista Tarjeta_Empleados
Esquemas
Un esquema es una forma de visualizar una base de datos más allá de
los datos que contenga actualmente. Para representar el esquema de una
base de datos relacional se debe dar el nombre de sus tablas, los atributos
de cada una de estas, los dominios sobre los que se definen estos atribu-
tos, las claves primarias y las claves foráneas (la definición y los ejemplos
acerca de claves foráneas los encontraremos en el capítulo 5).
» www.redusers .com
PHP .,. MYSQL DESDE CERO 35
• Uno a uno
• Uno a varios
• Varios a varios
1:1
Tabla A Tabla B
www.redusers.com «
36 2. BASES DE DATOS
l:n
/
-,
1I
Tabla A Tabla B
» www.redusers .com
PHP -e- MYSQL DESDE CERO [!J;j3;fi 37
n:n
/
Tabla A
'"
V <,
Tabla B
l:n n:1
/ e ~
Tabla A
-, Tabla
V
Tabla B
www.redusers.com «
38 ttfj#;f3 2. BASES DE DATOS
Páginas Nacionalidad
# Cod autor
# Cod libro
1:n n:1
/ r'\,
Tabla Autor
-, Tabla Autor_Libro
V
Tabla Ubro
Modalidad
La modalidad indica si es obligatorio o no que una instancia participe en
la relación. Vimos antes que, según la cardinalidad, existen relaciones del
tipo uno a varios, uno a uno y varios a varios. Lo que la modalidad agrega
a este tipo de relaciones es definir si es obligatorio o no la participación
de cada instancia en esa relación. Volviendo a los ejemplos anteriores:
» www.reduserscom
PHP + MYSQL DESDE CERO 39
I Obligatoria
o Opcional
Tabla A
1:" -/ Tabla B
-""
Figura 8. Ejemplo de modalidad en las relaciones.
www.reduaers.com «
40 2. BASES DE DATOS
• Rapidez
• Posibilidad de trabajar en diferentes plataformas
• Múltiples formatos de tablas para cada necesidad
• Seguridad
• Gran estabilidad
• Administración simple
• Soporte técnico (con el licenciamiento comercial)
Obtener MySQL
MySQL puede obtenerse de manera completamente libre a través de
cualquier tipo de distribución: revistas, Internet, copias en CDIDVD
provistas por amigos, etcétera. Pero, sin dudas, una de las formas más
utilizadas es acceder al sitio www.mysql.com ~y desde allí descargar la
» www.redusers .com
PHP + MYSQL DESDE CERO 41
• Linux
• Windows (9x, Me, NI, 2000, XP, Vista, 7)
• Solaris
• BSD (FreeBSD, NetBSD, OpenBSD, BSD/OS)
• Mac OS
• Novell NetWare (6.0 o superior)
• OS/2
• BeOS
• RISC OS
• SGI IRIX 6.5.x
• AS/400
Licencia de uso
11ySQL pone a disposición de los usuarios dos tipos de licenciamiento:
una licencia comercial y una licencia GPL (General Public License).
La licencia comercial brinda, entre otras cosas, soporte técnico y garantía.
Diseñar una base de datos es una tarea que necesariamente combina experiencia
práctica y conocimientos teóricos. En este capítulo hemos recorrido los conceptos
fundamentales para introducirnos en este apasionante tema y poder sacar provecho
de las opciones que nos ofrecerá MySQL.
www.redusers.com «
42 2. BASES DE DATOS
Actividades
TEST DE AUTOE\' AL{jACIÓ~
EJERCICIOS PRÁCTICOS
4 Cree el diseño de una base de datos en donde intervengan relaciones uno a varios
e implemente un esquema de integridad referencial como se hizo en este capítulo.
» www.redusers .com
En este capítulo, para poner en práctica lo aprendido, trabajaremos con
MySQL. Utilizaremos sus características generales; para esto debemos
saber que la creación de tablas es un proceso posterior al diseño de la
base de datos, requiere atención, análisis y un conocimiento profundo .
JI JI JI
44 3. MYSQL
Tipos de tablas
Cuando trabajamos con MySQL, existe la posibilidad de variar el tipo de
tabla una vez creada, salvo en el caso de las tablas del sistema -llamadas
MySQL y test-, qtle por defecto son MyISAM, y no se recomienda modificar-
las. Para indicar el tipo de tabla al crearla, usamos la siguiente sintaxis:
ISAM
MySQL empezó utilizando este tipo de tablas y, actualmente, se las consi-
dera en desuso. Entre sus desventajas figura el hecho de no poder transportar
ficheros entre máquinas con distinta arquitectura (tiene un formato distinto
para cada arquitectura/sistema operativo, lo cual resulta más rápido, pero
presenta el problema de la incompatibilidad) y el de no manejar ficheros de
tablas superiores a 4 gigabytes. Los índices se guardan en archivos .ISM y los
datos en archivos .ISD. MySQL recomienda actualizar este tipo de tablas hacia
las de tipo MyISAM. Esto puede hacerse con la siguiente instrucción SQL:
MyISAM
Es el tipo de tabla por defecto en MySQL desde la versión 3.23
Yestá basado en las ISAM, por supuesto, que ofrecen más opciones.
» www.reduserscom
PHP .,. MYSQL DESDE CERO 45
www.redusers.com «
46 3. MYSQL
=myísam-reccver
MERGE
Este tipo de tabla es muy utilizada en los casos en que se precisa tratar
a un número N de tablas l\1yISAl\1 (de idéntica estructura y pertenecientes
a la misma base de datos, de la que también deberá formar parte la tabla
MERGE) como si fuera una sola. Esto podría aplicarse si la tabla J\lfyISAl\1
original fuera de gran tamaño y acceder a su contenido llevara una canti-
dad considerable de tiempo y recursos. Obviamente, estamos hablando
de una tabla muy grande. Entre otras características, destacamos:
» www.redusers .com
PHP .,. MYSQL DESDE CERO 47
•
a mensaje
1 uno
2 dos
3 tres
1 cuatro
2 cinco
.
3 seis
HEAP
Este tipo de tablas tienen una particularidad que las distingue del
resto: son tablas en memoria, temporales y desaparecen cuando el ser-
vidor se cierra. Esto las hace realmente rápidas y, a diferencia de una
tabla TE1\1PORARY, que solo puede ser accedida por el usuario que la
crea, pueden ser utilizadas por diversos usuarios.
www.redusers.com «
48 3. MYSQL
InnoDB
Estas tablas, al igual que las Berkeley DB, son TST (Transactions Saje
Tables O tablas para transacciones seguras). Las tablas de este tipo son
más lentas y ocupan más memoria, pero a cambio ofrecen mayor segu-
ridad frente a fallas durante la consulta. Fueron agregadas en la versión
4.0 de MySQL y tienen las siguientes características:
» www.redusers .com
PHP .,. MYSQL DESDE CERO 49
BerkeleyDB
Estas tablas pueden ser usadas independientemente de MySQL; son
desarrolladas por otra empresa, Sleepycat, y MySQL ofrece una interfaz
para trabajar con ellas como una posibilidad más.
www.redusers.com «
50 3. MYSQL
Tipos de datos
En el momento de crear tablas de bases de datos, es muy importante
definir los tipos de datos. MySQL soporta una gran variedad de ellos,
uno para cada necesidad.
Cadenas de caracteres
Los subtipos de datos existentes aquí son eRAR, v ARCRAR, BLOB,
TEXT, ENUM, Y SET.
CHARyVARCHAR
Son muy similares, quizás la diferencia más notable es el modo de almace-
namiento. Cuando defmimos una columna tipo CRAR de tamaño N, e ingresa-
mos un valor (de menos de N caracteres) en esa columna, MySQL rellenará
con espacios lo que sobra, mientras que si hacemos lo mismo con una colum-
na de tipo VARCHAR, no se rellenará con espacios. Al obtener información a
través de una consulta SQL, no aparecen los espacios sobrantes, MySQL
» www.redusers .com
PHP + MYSQL DESDE CERO 51
BLOBy TEXT
Se utilizan para cadenas con un rango que dependerá del tamaño que
queramos almacenar. La diferencia entre ambos es que TEXT permite com-
parar dentro de su contenido sin distinguir mayúsculas y minúsculas, y
BLOB las distingue. Además, TEXT tiende a ser usado para cadenas de texto
plano (sin formato), mientras que BLOB se usa para objetos binarios, o sea,
cualquier tipo de datos o información, desde un archivo de texto con todo
su formato, incluyendo las imágenes, hasta archivos de sonido o video.
BLOB (Binary Large OBject, objeto binario de gran tamaño) se subdivide
en cuatro tipos que difieren solo en la capacidad máxima de almacena-
miento. Con TEXT sucede lo mismo e, incluso, hay correspondencia entre
la capacidad máxima de almacenamiento de unos y otros.
Cuando realizamos una consulta a un servidor de bases de datos, este nos devuelve
resultados que viajan a través de la red. Mientras más datos sean, más tráfico gene-
raremos; de ahí la importancia de construir nuestras instrucciones SQL con eficacia,
de manera de obtener estrictamente solo 10 que necesitamos.
www.redusers.com «
52 ttfj3¡fi 3. i\!fYSQL
ENUl\1
Este tipo de string puede seleccionar su valor únicamente de una lista fini-
ta (máximo de 65.535 elementos) de opciones definidas por el usuario y otras
dos por defecto (índice Oque significa error, por ingresos fuera de rango,
por ejemplo, y está representado por "", e índice NULLcon valor NULL).Por
ejemplo, definimos una columna con ENUNI("argelltina","lnexico","paraguay") :
SET
Similar a ENUNI en su funcionamiento, solo que se puede seleccionar nin-
guno o más de un valor de la lista (hasta 64, la muestra separada por comas).
» www.redusers .com
PHP .,. MYSQL DESDE CERO 53
Numéricos
Existen los subtipos DECIMAL (NUMERIC o DEC), INTEGER (INT),
TINYINT, BIT, BOOL, l\IIEDIUMINT, BIGINT, SMALLINT, FLOAT y DOUBLE
(DOUBLE PRECISION o REAL). Todos los tipos numéricos pueden definir-
se con dos parámetros opcionales: UNSIGNED (impide que los campos
numéricos acepten signo negativo, es decir, solo se aceptarán el cero
y los valores positivos) y ZEROFILL (completa con ceros a la izquierda
hasta la longitud máxima). La forma de uso es:
Por ejemplo,
TINYINT[(M)], BIT
Un tipo de datos BIT nos es útil para almacenar valores de un bit.
Si se omite o se sobrepasa la capacidad de TINYINT, se toma la cantidad
máxima soportada por este tipo de dato. Si se define con signo, va desde
-128 a 127, en cambio, sin signo ( UNSIGNED), va desde Ohasta 255.
BIT es un TINYINT de un dígito (TINYINT(I)) .
www.redusers.com «
54 3. MYSQL
SMALLINT[(M)]
Este es un tipo numérico exacto que podemos utilizar. Si se omite o se
sobrepasa la capacidad de SMALLINT, se toma la cantidad máxima sopor-
tada por este tipo de dato. Si se define con signo, va desde -32768 a 32767,
en cambio, sin signo (UNSIGNED), va desde O hasta 65535.
MEDIUMINT[(M)]
Es otro tipo numérico exacto que podemos utilizar, de mayor capaci-
dad al anterior. Si se omite o se sobrepasa la capacidad de :MEDIUNfINT,
se toma la cantidad máxima soportada por este tipo de dato. Si se defi-
ne con signo va desde -8388608 a 8388607, en cambio, sin signo (UNSIG-
NED), va desde Ohasta 16777215.
INT[(M)] e INTEGER[(M)]
Este tipo de dato es el utilizado con mayor frecuencia en los lengua-
jes de programación y se destina para albergar un valor entero bastante
grande. Si se omite o se sobrepasa la capacidad de INT, se toma la can-
tidad máxima soportada por este tipo de dato. Si se define con signo va
desde el valor -2147483648 al valor 2147483647, en cambio, cuando care-
ce de signo (UNSIGNED), va desde O hasta 4294967295. INTEGER[(M)] es
sinónimo del tipo de dato INT .
llIGINT[(M)]
Es uno de los tipos que soportan un valor entero realmente enorme
para transacciones de cálculos científicos o valores muy grandes.
Si se omite o se sobrepasa la capacidad de BIGINT, se toma la cantidad
máxima soportada por este tipo de dato. Si se define con signo va des-
de -9223372036854775808 a 9223372036854775807, en cambio, sin signo
(UNSIGNED) va desde O hasta 18446744073709551615. Todas las funciones
matemáticas trabajan internamente con valores BIGINT.
» www.redusers .com
PHP -s- MYSQL DESDE CERO [!fi3;fi 55
FLOAT[(M,D)]
Sirven para definir números con coma, con menos precisión
que DOUBLE. El rango de posibles valores va desde -3.402823466E+38
a -1.175494351E-38 ,yO Ydesde 1.175494351E-38 a 3.402823466E+38 .
Es un estándar que permite normalizar las consultas realizadas sobre una base de
datos. En general, posibilita el manejo de los datos (inserción, actualización, eliminar,
etc.) de una base de datos. La mayoría de motores de bases de datos lo implementan:
SQL server, Oracle, Sybase, Postgres, entre otros.
www.redusers.com «
56 ttfj#;f3 3. MYSQL
1 -128 127
O 255
3 -8388608 8388607
O 16777215
Fecha y hora
Los subtipos de datos existentes son DATETIME ,DATE, TIMESTAMP,
TIME Y YEAR.
DATE TIME
Se utiliza para trabajar con fechas y horarios a la vez. El formato por
defecto es 'YYYY-MM-DD HH:MM:SS' , pero se le puede dar otro formato
si por algún motivo necesitáramos hacerlo, por ejemplo: 'YYYYIMMIDD
HH%MM%SS'. El rango va desde '1000-01-0100:00:00' a '9999-12-3123:59:59' .
Si en el momento de ingresar un DATETIME definimos un valor inválido
(por ejemplo, minuto superior a 60), se almacenará la fecha nula; para el
formato 'YYYY-l\tIM-DD HH:MM:SS' seria '0000-00-00 00:00:00'
» www.reduserscom
PHP .,. MYSQL DESDE CERO 57
DATE
Se utiliza para trabajar solo con fechas. El formato por defecto es
'YYYY-MM-DD', pero se le puede dar otro formato si por algún motivo nece-
sitáramos hacerlo, por ejemplo: 'YYYY*MM*DD' . El rango va desde' 1000-01-01'
a '9999-12-31'. Si en el momento de ingresar un DATE definimos lID valor
inválido (por ejemplo, mes superior a 12), se almacenará la fecha nula;
para el formato 'YYYY-MM-DD' seria '0000-00-00' .
TIMESTAMP
Combinación de fecha y hora. El rango va desde el 01-enero-1970 al
año 2037. El formato de almacenamiento depende del tamaño del campo
y se visualiza como un número.
T TA.c'fA.'"O T FOR..'fATO
Tli\1ESTAi\1P(8) YYYYNIYIDD
Tli\1ESTAi\1P(6) YYMMDD
TIMESTAlVIP(4) YYNlN!
Tli\1ESTAl\-IP(2) yy
www.redusers.com «
58 3. MYSQL
TIME
Se utiliza para trabajar solo con horarios. El formato por defecto es
'HH:Nilv1:SS' (aunque también soporta 'HHH:Nilv1:SS' para períodos largos de
tiempo), pero se le puede dar otro formato si por algún motivo necesitá-
ramos hacerlo, por ejemplo: 'HH*N1M*SS'. El rango va desde '-838:59:59' a
'838:59:59' (el hecho de poder almacenar TINIE negativos nos da la pauta
de que existen más usos que el de simplemente almacenar el horario de
un determinado suceso). Si en el momento de ingresar un TINlE, definimos
un valor inválido (por ejemplo, minuto superior a 60) se almacenará la fecha
nula, para el formato 'HHJ"W:DD' sería '00:00:00'. Si ingresamos valores fue-
ra de rango, estos valores se reemplazan por el extremo más cercano.
YEAR
Se usa para representar años. Su formato es por defecto 'YYYY' (puede
definirse como ,yy,). El rango va desde 1901 hasta 2155. Si se representa el
año con solo dos dígitos, surge la siguiente particularidad: si se define
» www.redusers .com
PHP + MYSQL DESDE CERO 59
Fleld [ :
Type (!) ~CHAR
VARCHAR •
LengthNalues 1
TINY1NT
Collation TEXT
Attributes DATE •
SMALLlNT
Null I'vIEDIUI'vIlNT
Defaultl INT
BIGINT
Extra FLOAT
mil DOUBLE
DECIMAL
~ DATETIME
f!ilj TIMESTAMP
- TIME
y.~ __
Referencia de funciones
Los sistemas gestores de bases de datos, normalmente, vienen con
funciones incorporadas para mejorar y hacer más sencillas las consultas
que se realizan a una base de datos. La mayoría de estas funciones forman
parte del lenguaje SQL estándar, pero hay otras que son específicas de
algún gestor de bases de datos, lo que significa que existen grandes posi-
bilidades de que, al migrar de Ull sistema gestor de bases de datos a otro,
estas funciones no sean reconocidas, es decir, no sean compatibles.
Una de las cosas que hacen popular a una base de datos, dentro del
ámbito informático, es el hecho de que respeten el estándar ANSI SQL,
pero eso no se contradice con que cada base mejore las prestaciones e
incorpore funciones propias: queda a criterio de los usuarios utilizar
www.redusers.com «
60 3. MYSQL
INSERT
UPDATE Lenguaje de manipulación
DELETE de datos (DML)
CREATE
ALTER Lenguaje de definición
DROP de datos (DDL)
RENAME
» www.reduserscom
PHP + MYSQL DESDE CERO 61
ASCII(str)
Devuelve el valor del código ASCII del primer carácter del parámetro.
Por ejemplo, la consulta:
SELECT ASCII('2');
//Devuelve 50 que es el código ASCII que representa al carácter '2'.
Esta función devuelve Osi str es una cadena vacía y NULL si es nula.
BINARY
Es en realidad un operador y puede utilizarse para forzar comparacio-
nes sensibles a mayúsculas y minúsculas. Por ejemplo:
Es una buena costumbre definir como numéricos solo aquellos campos sobre los cuales
se realizarán operaciones matemáticas, como el número de productos de una empresa.
Pero en el caso de, por ejemplo, números de documento o códigos postales, esto no se-
ría necesario, recordemos que estas decisiones dependerán particularmente del sistema.
www.reduaers.com «
62 3. MYSQL
BIT_LENGTH(str)
Devuelve la longitud de la cadena str en bits.
SELECT CHAR(77,121.4,83,81,'76');
//Devuelve 'MySQL'
CHAR_LENGTH(str), CHARACTER_LENGTH(str),
LENGTH(stl~)y OCTET_LENGTH(stl~)
Devuelven la longitud de str.
» www.redusers .com
PHP + NIYSQL DESDE CERO 63
Si bien hay muchas aplicaciones que nos permiten acceder a las funciones de MySQL de
forma gráfica, la línea de comandos de MySQL no deja de ser útil y muy utilizada hoy en día.
www.reduaers.com «
64 3. MYSQL
INSERT
(str, pOS, len, nuevacadena)
Devuelve la cadena str reemplazando su contenido desde la posición
pos hasta la posición pos + len por la cadena nuevacadena.
» www.reduserscom
PHP .,. MYSQL DESDE CERO [!j;j3;fi 65
INSTR(str,subcadena)
Vea la función POSITION.
LCASE(str) y LOWER(str)
Devuelven la cadena str en minúsculas. Para pasar a mayúsculas ver UCASE.
LEFT( str, N)
Devuelve N caracteres de la cadena str empezando desde la izquierda.
LIKE
Es muy utilizada y trae muchos beneficios al permitirnos incorporar las
llamadas expresiones regulares (que podemos encontrar en el estándar ANSI
SQL) en nuestras consultas SQL. Devuelve 1 si hubo coincidencias y O si no.
OPERADORES
www.redusers.com «
66 3. MYSQL
Por ejemplo:
» www.redusers .com
PHP .,. MYSQL DESDE CERO 67
LOCATE(subcadena, str)
Devuelve la posición de la primera ocurrencia de subcadena en str (Osi
no hay coincidencias). Es similar a INSTR solo que los argumentos están
en orden inverso (primero str y luego subcadena). Si se le da un tercer argu-
mento (POS), la función comenzará a buscar coincidencias a partir de POS.
www.redusers.com «
68 3. MYSQL
LTRIM(str)
Devuelve la cadena str sin los espacios a la izquierda (si es que los tiene):
» www.reduserscom
PHP -s- MYSQL DESDE CERO 69
Donde las columnas que se utilizan en MATCH tienen que haber sido
previamente definidas en FULLTEXT en el momento de crear la tabla.
POSITION(subcadena IN str)
Devuelve la posición de la primera ocurrencia de subcadena en str o
O si no hay coincidencias. Esta función tiene la misma funcionalidad que
LOCATE, solo cambia la forma de pasarle los argumentos.
Por ejemplo:
QUOTE(str)
Esta función fue agregada en MySQL versión 4.0.3. Reemplaza los caracte-
res que correspondan por sus respectivas secuencias de escape.
SELECT QUOTE("D'alessandro");
/!Devuelve 'D\'alessandro'
www.redusers.com «
70 3. MYSQL
REPEAT(str, N)
Devuelve str concatenada N veces o NULL si str o N es nulo.
REVERSE(str)
Devuelve la cadena str en orden inverso.
RIGHT(str, N)
Devuelve N caracteres de la cadena str empezando desde la derecha.
» www.redusers .com
PHP + MYSQL DESDE CERO 71
RTRIM(str)
Devuelve la cadena str sin los espacios a la derecha (si es que los tiene).
Como el ejemplo que aparece a continuación. Ver también LTRIlVI, TRIM.
SPACE(N)
Devuelve una cadena compuesta por N espacios.
STRCMP(strl, str2)
Devuelve Osi strl y str2 S011 iguales, -1 si strl es más chico (de acuerdo
al ordenamiento actual) que str2, y 1si str2 es más chico (de acuerdo al
ordenamiento actual) que strl . Por ejemplo:
www.reduaers.com «
72 ttfj#;f3 3. MYSQL
SUBSTRING(str,pos,len)
También admite la forma SUBSTRING(strFROM pos FOR len) .
Ver la función MID.
La utilidad de las funciones provistas por MySQL es muy poderosa, pero se puede
incrementar anidando las funciones para obtener el resultado buscado.
» www.redusers .com
PHP + MYSQL DESDE CERO 73
UCASE(str) y UPPER(str)
Devuelven la cadena str en mayúsculas. Para pasar a minúsculas ver LCASE
-(X)
Cambia de signo el argumento. Por ejemplo:
www.reduaers.com «
74 3. MYSQL
SELECT -(-2);
//Devuelve 2
ABS(X)
Devuelve el valor absoluto del número X.
ACOS(X)
Devuelve el arco coseno de X ex son radianes).
ASIN(X)
Devuelve el arco seno de X ex son radianes).
ATAN (X)
Devuelve el arco tangente de X ex son radianes).
CEILING(X)
Devuelve el entero (en formato BIGINT) inmediatamente superior a X.
Por ejemplo:
SELECT FLOOR(1.23);
//Devuelve 2
SELECT FLOOR(-1.23);
//Devuelve -1
COS(X)
Devuelve el coseno de X ex son radianes).
» www.redusers .com
PHP .,. MYSQL DESDE CERO 75
COT(X)
Devuelve la cotangente de X ex son radianes).
DEGREES(X)
Devuelve X (se suponen radianes) convertido a grados.
DIV
Operador, realiza una división y devuelve como resultado un número
entero. Por ejemplo:
SELECT 7 DIV 2
//Devuelve 3
SELECT 3/5;
//Devuelve 0.60
EXP(X)
Devuelve el número entero (2.718281828 ... ) elevado a la X.
FLOOR(X)
Devuelve el entero (en formato BIGINT) inmediatamente inferior a X.
Por ejemplo:
www.redusers.com «
76 3. MYSQL
SELECT FLOOR(1.23);
//Devuelve 1
SELECT FLOOR(-1.23);
//Devuelve -2
GREATEST(X,Y, ...)
Similar a LEAST, devuelve el mayor de los argumentos.
LEAST(X,Y, ...)
Similar a GREATEST, pero devuelve el menor de los argumentos.
Por ejemplo:
» www.redusers .com
PHP -s- MYSQL DESDE CERO 77
SELECT LEAST(2,O);
//Devuelve O
SELECT LEAST(34.0,3.0,5.0,767.0);
//Devuelve 3.0
LN(X)
Devuelve el logaritmo natural de X. Disponible desde la versión 4.1.3.
LOG([B,] X)
Devuelve el logaritmo en base B (si B no se pasa, se asume logaritmo natu-
ral) de X La opción de la base arbitraria está disponible desde la versión 4.0.3.
MOD(N,M)
Devuelve el resto de dividir N por NI. Puede utilizarse también el signo %.
SELECT lVIOD(29,9);
//Devuelve 2
SELECT 29 % 9;
//Devuelve 2
www.redusers.com «
78 3. MYSQL
SELECT 29 MOD 9;
//Devuelve 2
PIO
Devuelve el valor de PI.
POW(X,Y) y POWER(X,Y)
Devuelven el valor que se obtiene al elevar X a la potencia Y.
RADIANS(X)
Devuelve X (se suponen grados) convertido a radianes.
RAND([N])
Si no se le da ningún argumento, devuelve un valor aleatorio entre O y l.
Si se le da el argumento N (entero) hace lo mismo, pero mantiene el valor
obtenido para sucesivas llamadas. Por ejemplo:
SELECT RANDO;
//Devtlelve 0.17573482386203
SELECT RAl"\TD(20);
/!Devuelve 0.15888261251047
SELECT RA..,\1J)(20);
/!Devuelve 0.15888261251047
» www.reduserscom
PHP -s- MYSQL DESDE CERO 79
SELECT RA.'\TOO;
//Devuelve 0.44566677782312
ROUND(X [,D))
Devuelve el número X y lo redondea tomando D posiciones decimales
(O si no se da D). Por ejemplo:
SELECT ROIDTJ>(1.58);
/!Devuelve 2
SIGN(X)
Devuelve el signo de X(-l si es negativo, Osi es 0,1 si es positivo).
SIN(X)
Devuelve el seno de X ex son radianes).
www.redusers.com «
80 tUja;f3 3. MYSQL
SQRT(X)
Devuelve la raíz cuadrada de x.
TAN(X)
Devuelve la tangente de X (X son radianes).
TRUNCATE(X,D)
Devuelve X truncado a D decimales. Truncar no significa redondear,
sino tomar D decimales. Si D es negativo, devuelve la parte entera de X
y pone a O los últimos D dígitos de X Por ejemplo:
SELECT TR~CATE(1.999,O);
//Devuelve 1
Hay funciones matemáticas que tal vez la mayoría de los usuarios no utilicemos nun-
ca, pero son muy útiles para programar aplicaciones orientadas al cálculo de proba-
bilidades y estadísticas de sucesos, al poder unir el hecho de manejar una enorme
cantidad de datos con una gran precisión en los cálculos.
» www.redusers .com
PHP + MYSQL DESDE CERO 81
CURDATEOy CURRENT_DATE
Devuelven la fecha actual en formato 'YYYY-MM-DD' o YYYThllv1DD
(si se pone CURRENT_DATEO + O).
CURRENT_TIl\fE y CURTIl\fEO
Devuelven el horario actual en formato 'HHJvIN1:SS' o HH:NINlSS
(si se pone CURRENT_TI:NIEO + O).
CURRENT TIMESTAl\fP
Ver la función NO\V.
DATE_FORMAT(date,formato)
Da formato a una fecha. Existen las siguientes opciones
(atención a las mayúsculas y minúsculas):
www.reduaers.com «
82 ttfj#;f3 3. MYSQL
FORMATO DE FECHAS
T SIGNO T DESCRIPCIÓN
%D Número de día del mes en inglés (Oth, 1st, 2nd, 3rd ...).
%X Cada año tiene una cantidad de semanas. Cada semana tiene un número.
Una semana perteneciente a un año (que comienza en ese año) puede terminar
en el rulo siguiente. Lo que hace este formato es devolver el rulo (4 dígitos)
al que pertenece la semana de la fecha en cuestión. Torna COtUO primera
semana a la 01 y como primer día de la semana al domingo.
%1 Lo mísmo que %X, pero toma como primer día de la semana el lunes.
°10 e Número de día del mes (0 ...31), uno o dos dígitos según corresponda.
°Alc Número de mes (0 ... 12), uno o dos dígitos según corresponda.
» www.reduserscom
PHP + MYSQL DESDE CERO [!fj3;fi 83
%p AMoPM.
Número de semana del año (00 ...53) (domíngo como primer día).
%0 Número de semana del año (OO... 53) (lunes como primer día).
%Y Número de semana del año (01. ..53) (domíngo como primer día).
%v Número de semana del año (01. ..53) (lunes como primer día).
Cuando trabajamos con funciones para el manejo de fechas y horas, debemos tener
en cuenta que toman como tiempo actual los horarios del lugar en donde se encuentre
instalado el servidor de bases de datos. Un ejemplo es la función NOW().
www.redusers.com «
84 3. MYSQL
Por ejemplo:
DAYNAME(date)
Devuelve el nombre (en inglés) del día de la fecha date. Por ejemplo:
SELECT DA~AME("1998-02-05");
//Devuelve 'Thursday'
» www.reduserscom
PHP T MYSQL DESDE CERO 85
DAYOFMONTH(date)
Devuelve el número del día dentro del mes (desde 1 a 31) de la fecha date.
DAYOFWEEK(date)
Devuelve el n-úmero de día de la fecha date ( 1 para domingo, 2 para lunes ...
7 para sábado). Es similar a ~'EEKDAY, pero numera los días de otra manera.
DAYOFYEAR(date)
Devuelve el número del día dentro del año (desde 1 a 366) de la fecha date.
FROM_DAYS(N)
Es la función inversa a TO_DAYS : devuelve la fecha que se obtiene
sumando N días al año o. Por ejemplo:
www.redusers.com «
86 3. MYSQL
HOUR(time)
Devuelve la hora del horario time (desde Oa 23). Por ejemplo:
SELECT BOUR('lO:05:03');
//Devuelve 10
MINUTE(time)
Devuelve los minutos del horario time (desde Oa 59).
MONTH(date)
Devuelve el número de mes (desde 1 a 12) de la fecha date.
MONTHNAME(date)
Devuelve el nombre (en inglés) del mes de la fecha date. Por ejemplo:
» www.redusers .com
PHP .,. MYSQL DESDE CERO 87
SELECT MO~TIDAl'¡IE("1998-02-05");
//Devuelve 'February'
NOWO y SYSDATEO
Devuelve la fecha y hora actuales en formato 'YYYY-:MM:-DD HH::MM::SS'
o YYYY:MM:DDllHNiMSS (si se pone NOWO+ O).
PERIOD_ADD(P, N)
Suma N meses a P. P es un periodo de formato YY:MM: O YYYY:MM:
(como agosto de 1999 puede ser 9908 O 199908). El valor devuelto es
de tipo YYYY:MM:. Por ejemplo:
PERIOD _DIFF(Pl,P2)
Devuelve el número de meses entre el período PI y P2 (que solo pueden
ser de formato YYMl\1 o YYYYWv1). Por ejemplo:
QUARTER(date)
Divide al año en cuatro periodos de tres meses cada uno y devuelve
el periodo al que pertenece la fecha date. Por ejemplo:
www.redusers.com «
88 3. MYSQL
SELECT QUARTER('98-04-01');
//Devuelve 2
SECOND(time)
Devuelve los segundos del horario time (desde Oa 59). Por ejemplo:
SEC_TO_TIME(segundos)
Convierte los segundos al formato 'HH:NINI:SS' o HHNINISS (si se pone
SEC _TO _TINIE( segundos) + O ).
» www.redusers .com
PHP -s- MYSQL DESDE CERO [!fi3;fi 89
SECOl\"D SECONDS
HOL"R HOURS
DAY DAYS
MOl"TH MONTHS
YEAR YEARS
• Utilizando signos:
www.redusers.com «
90 3. MYSQL
• Utilizando la función:
• Utilizando signos.
• Utilizando función.
Devuelve 1998-01-0100:01:00 .
Para sumar una hora a la fecha dada:
» www.redusers .com
PHP "1" MYSQL DESDE CERO 91
Devuelve 1998-02-28.
En esta última consulta, sumamos un mes a partir del 30 de enero.
Como febrero no tiene día 30 se asume el día más cercano, o sea, su últi-
mo día (28). Las funciones ADDDATEO y DATE_ADDO son idénticas.
Las funciones SUBDATEO y DATE:._SUBO son idénticas.
TIME_FORMAT(time, formato)
Funciona del mismo modo que la función DATE_FORMAT(), solo que puede
utilizar nada más que los formatos referidos a horas, minutos y segundos.
TIME_TO_SEC(time)
Convierte time a segundos. Por ejemplo:
_ _
SELECT TThIE TO SEC('22:23:00');
//Devuelve 80580
TO_DAYS(date)
Es la función inversa a FROM_DA YS . Devuelve la cantidad de días desde
el año Ohasta la fecha date. Por ejemplo:
SELECT TO _DAYS('1997-10-07');
//Devuelve 729669
www.redusers.com «
92 3. MYSQL
WEEKDAY(date)
Devuelve el número de día de la fecha date ( Opara lunes, 1 para
martes,2 para miércoles ... 6 para domingo). Es similar a DAYOF\VEEK ,
pero numera los días de otra manera.
» www.redusers .com
PHP + MYSQL DESDE CERO 93
YEAR(date)
Extrae el año de la fecha date. Por ejemplo:
SELECT YEAR('98-02-03');
//Devuelve 1998
YEARWEEK(date [, inicio])
Devuelve el año y el número de semana de la fecha date. El segundo
argumento es opcional y funciona igual que el segundo argumento de
la función WEEK.
Funciones de conversión
Estas funciones nos permiten tomar el valor almacenado en otras
variables y convertirlos en el tipo de datos que deseemos (en la medida
que 10 permita la función). Veamos su uso.
CAST(expresion AS tipo)
La función CASI se utiliza para convertir un tipo de dato en otro.
El argumento tipo puede ser:
Al utilizar una u otra función debemos considerar la versión del servidor de bases de datos
MySQL, en donde se alojará el sitio web, Una función no soportada nos obligaría a replan-
tear partes del código fuente de la aplicación. Podemos recurrir a la ayuda y a los progra-
mas de MySQL para conocer la versión del servidor y los requerimientos de las funciones.
www.redusers.com «
94 3. MYSQL
• BINARY
• CRAR (desde versión 4. O. 6)
• DATE
• DATETUvIE
• SIGNED (entero con signo)
• TINlE
• UNSIGNED (entero sin signo)
» www.redusers .com
PHP .,. MYSQL DESDE CERO [y;,a;fi 95
Operadores de comparación
Las comparaciones pueden devolver tres valores O(falso), 1 (verdadero)
y NULL (nulo). Si en una comparación por lo menos uno de los elementos
que se están comparando es NULL, la comparación dará como resultado
NULL, excepto si se usa el operador de comparación <->
OPERADORES DE COMPARACIÓN
Menor o igual que <= SELECT 1 -c= 1, 1 -c= 10, 1 <= l\'ULL;
/1D~yo~lv~
1, 1, l\'ULL
Mayor o igual que >= SELECT 1 >= 1, 1 >= 10, 1 >= NULL;
//Devuelve 1, O,NULL
www.redusers.com «
96 ttfj#;f3 3. MYSQL
Operadores lógicos
Los operadores lógicos, al igual que en el desarrollo, son muy útiles
para realizar comparaciones de valores o estados de diferentes elementos.
En SQL, todos los operadores lógicos se evalúan como TRUE, FALSE,
o NULL. En MySQL, se implementan como 1 (TRUE), O (FALSE), y NULL.
NOTo!
Negación. Por ejemplo:
SELECT !(1+1);
//Devuelve ° (1+1=2, 2 es distinto de 0, 2
es verdadero, lo distinto de verdadero es falso)
SELECT! 1+1;
// Devuelve 1 (atencion los parentesis! Es equivalente a !(1) + 1:
lo distinto de 1 es falso, o sea 0, y 0+1=1, que es verdadero)
» www.reduserscom
PHP + MYSQL DESDE CERO 97
SELECT 1 && 1;
//Devuelve 1
SELECT 1 && O;
//Devuelve O
OR 011
Devuelve 1 si alguno de los operandos es verdadero, NULL si alguno
es NULL y el otro es O; si no, devuelve o. Por ejemplo:
SELECT 1111;
//Devuelve 1
SELECT 1 11 O;
//Devuelve 1
SELECT O 11 O;
//Devuelve O
SELECT O 11 NULL;
//Devuelve NULL
SELECT 1 11 NULL;
//Devuelve 1
www.redusers.com «
98 3. MYSQL
XOR
Devuelve 1 si y solo si únicamente uno de los operandos es 1,a menos que
el otro sea NULL, en cuyo caso devuelve NULL; si no, devuelve O.Por ejemplo:
SELECT 1 XOR 1;
//Devuelve O
SELECT 1 XOR O;
//DeVllelve 1
» www.redusers .com
PHP .,. MYSQL DESDE CERO 99
PROMPT DE MYSQL
,> Esperando la siguiente línea, hay una cadena abierta con' (comillas simples).
'> Esperando la siguiente línea, hay una cadena abierta con" (comillas dobles).
www.redusers.com «
100 3. MYSQL
Algunos ejemplos:
fvlYSQL> EXIT
» www.redusers .com
PHP .,. MYSQL DESDE CERO 101
~(ySQL -?<enter>
Realizamos una introducción a MySQL y analizamos las posibilidades que puede brindar-
nos. Algunas de ellas son: los tipos de tablas y los tipos de datos soportados para definir
campos. Por último, repasamos las funciones e iniciamos el uso del monitor MySQL.
www.redusers.com «
102 tUja;f3 3. MYSQL
Actividades
TEST DE AUTOEV ALlJACIÓ~
EJERCICIOS PRÁCTICOS
» www.redusers .com
PHPy
En este capítulo, conoceremos las distintas alternativas que nos
ofrece el lenguaje PHP para acceder e, incluso, definir estructuras
de bases de datos en MySQL. Comenzaremos con las sintaxis
de funciones, analizaremos sus diferencias, y veremos algunos
ejemplos y comentarios sobres ellas .
JI JI JI
104 4. PHP Y MYSQL
mysql_connect
Esta función intenta conectar a una base de datos y requiere que se le
pasen, de manera opcional, los siguientes argumentos (en este orden):
» www.redusers .com
PHP -s- MYSQL DESDE CERO 105
mysql.default_port =
(puerto por defecto)
mysql.default_host =
(nombre del servidor por defecto)
mysql.default_user =
(nombre de usuario por defecto)
mysql.defaultpassword =
(clave de usuario por defecto)
Para completar las opciones del php.ini, simplemente tenemos que escri-
bir la información a continuación del signo igual. Por ejemplo, para com-
pletar solo el usuario y el nombre del servidor:
mysql.default_port =
mysql.default_host = "168.22.22.9"
mysql.default_user = "pepe"
mysql.defaultpassword =
www.redusers.com «
106 4. PHP Y MYSQL
PHP tiene valores por defecto (no incluidos en el php.ini) qlle se utilizan
cuando un argumento fue omitido en la llamada a mysql_connect y, además,
no tiene un valor asociado en el php.ini. Estos valores son:
» www.reduserscom
PHP -s- MYSQL DESDE CERO [!fi3;fi 107
defecto del php.ini, pero tengamos en cuenta que cualquiera que tenga ac-
ceso a ese archivo podrá ver esa información. Incluso a través de PHP se
puede utilizar la función get_cfg_var("mysql.default_passvvord") y ver la con-
traseña escrita alli. Esta función devuelve 1 (verdadero) si nos conectamos
y O (falso) si algo falló. Cuando se logra la conexión, devuelve, además,
un identificador de conexión. Por ejemplo, en la siguiente conexión,
$id_conexion sería el identificador de conexión:
rnysql_pconnect
Funciona de manera similar a mysql_connect con la diferencia de que
las conexiones abiertas con mysql_pconnect (la p significa persistente)
no se cierran -persisten- cuando termina la ejecución del archivo PHP
(con mysql_connect sucede esto). Si al llamar a esta función ya existía
una conexión abierta idéntica, se utiliza esa conexión, de lo contrario,
se la crea. La calificación idéntica quiere decir que los argumentos
www.redusers.com «
108 4. PHP Y MYSQL
Ejecución de sentencias
Luego de crear la instrucción SQL, hay que enviarla al servidor
para que este la resuelva. PHP nos ofrece dos funciones para hacerlo:
mysql, db_query y mysql query .
rnysql_ db _ query
Los argumentos que espera son:
Ejemplos de la función:
» www.redusers .com
PHP + NIYSQL DESDE CERO 109
<?php
$consulta _sql = "select * from alumnos";
mysql_ db_query("base _ejemplo", $consulta _sql);
?>
<?php
mysql_db_query("base_ejemplo", "select * from alumnos");
?>
<?php
$identificador = mysql_connect("168.22.22.3", "pepe", "grillo");
$consulta _sql = "insert into alumnos values (1, 'julian maidana')";
mysql_db_query("base _ejemplo", $consulta _sql, $identificador);
?>
mysql_ query
Su sintaxis es la siguiente:
mysql_query("instruccion", identificador);
www.reduaers.com «
110 4. PHP Y MYSQL
mysql_create_db
La sintaxis para utilizar esta función es la siguiente:
» www.redusers .com
PHP -s- MYSQL DESDE CERO 111
<?php
Scoo = mysql_coooect("localhost", "u", "p");
Sbas = mysql, create _db("mibase");
Ilen este caso se crea la base utilizando el
Ilidentificador Scon, qlIe fue el último abierto.
?>
<?php
?>
<?php
www.redusers.com «
112 4. PHP Y MYSQL
•
_f_
.. TDOS9STI\QF(C:) • w.mp • bIn • my<ql • mysqIS,S.a • dota •
s..m
F''IOfJtd
~ 0.,. mod/o<tl T~
.o..k1.p .......pI•• 1110 '2011 120 S 10M fiel d•
Oo..nlo.cH rny.ql l'9201111>1 PM role I d.
Otopbo>c ptrlonn.n,t_Kt1cml 1¡g11Ol111~ PI.! J 1" de
~t<tntPl,eu Icsl II!1 .!Oll 11A8 PM F 1.'oId"
Ft.nk".ptd 1'9'2Ol11151 PM PID F.. IKB
l¡b,,"t. ,bJ.gf,'tO 1 '10'201112.03 AM FI. S1.l0~B
• Oocumtl'l's 'bJ.gf,'d 119701111 SI PM FI. SIlO KB
JI MUI'. ,bd.t.l 110 101112.03 AM fIle 18.412 KB
... PICW,tS my.ql. b,n.OOOOOl 1·10201111 SAM 000001 F,I. lKB
8 V,d ••• mysql. bin.lndex 1!,) '201111 SI PM IIIOEX Fj, lKB
Para eliminar una base de datos desde PHP, puede usarse la función
mysql dropjíb :
» www.redusers .com
PHP T MYSQL DESDE CERO [!JOOj3;fi 113
mysql_select_db
Su sintaxis es la siguiente y los parámetros son iguales a los utilizados
en mysqljcreatejíb:
www.redusers.com «
114 4. PHP Y MYSQL
<?php
Slink = mvsql
.. -eonneet("loealhost" , "u" , "p");,
Ssel_base = mysql, seleet_db("basel ");
?>
Esta función devuelve true (verdadero) si tuvo éxito y false (falso) si algo
falló (por ejemplo, si no hubiese ninguna base de datos con ese nombre).
<?php
l/cargamos en una variable toda la consulta
Stabla = "create table t l (";
Stabla .= "el int(4) unsigned not null,";
Stabla .= "e2 varehar(lOO))";
Stabla .= "ENGINE=myisam";
lila ejecutamos
if (mysql_query($tabla)) {
echo "tabla creada";
} else {
echo "error al crear la tabla";
}
?>
» www.redusers .com
PHP -e- MYSQL DESDE CERO 115
<?php
Ilcreamos la consulta
Sborrar jabla = "drop table tI";
l/la ejecutamos
if (mysql_query(Sborrar_tabla» {
echo "tabla eliminada'" ,
} else {
echo "error al eliminar la tabla";
}
?>
<?php
Ilcreamos la consulta
Ssql = "ALTER TABLE u MODIFY e2 BIGINT NOT NULL";
l/la ejecutamos
ir (mysql_query(Ssql» {
echo "tabla modificada'" ,
} else {
echo "error al modificar la tabla";
}
?>
www.redusers.com «
116 4. PHP Y MYSQL
rnysql_list_ dbs
La sintaxis de la función es:
mysql_list_ dbs(idenfificador);
Para darse una idea de hasta dónde se puede llegar utilizando en conjunto PHP y
l\llySQL, podernos ponercomoejemplouna aplicacióncomo PHPl\iyAdmin , que, más
allá de ser utilizadapor un grannúmerode usuarios, es realmentemuy completay
detallada en lo que respecta a sus funcionalidades.
» www.redusers .com
PHP .,. MYSQL DESDE CERO [!j;j3;fi 117
<?php
Sres = mysql_list_dbs($link);
$i = O;
whíle ($i < mysql_fetch _ro,v($res» {
echo mysql_ tablename(Sres, Si);
echo "<BR />".,
Si++;
}
?>
Las bases de datos no son propiedad exclusiva de intemet: su ámbito depende, como
casi todas las cosas, de qué queramos hacer con ellas. Tengamos presente este con-
cepto a la hora de elegir el lugar en donde guardar los datos, puede que no siempre
se precise utilizar las prestaciones de un servidor.
www.redusers.com «
118 4. PHP Y MYSQL
<?php
Sres = mysql_list_dbs($link);
whíle ($i = mysql_fetch_object($res» {
echo $i->Database."<br />";
}
?>
Si bien es posible crear tanto bases de datos como tablas desde PHP, también podemos
hacerlo desde aplicaciones dedicadas a trabajar con J\iIySQL.La ventaja de trabajar de esta
forma es que estas aplicaciones nos brindan posibilidades avanzadas y estandarizadas
para mantener bases de datos. Además, podremos ejecutarlas sin tener instalado PHP.
» www.redusers .com
PHP .,. MYSQL DESDE CERO 119
mysql_list_ tables
Cumple la misma función que mysql_list_dbs, pero en vez de devolver un
puntero al primer elemento de una lista de bases de datos, lo devuelve al
primer elemento de una lista de tablas de una base de datos. Aquí también
es posible usar la función mysql_tablename explicada en rnysql_list_dbs:
Veamos un ejemplo:
<?php
Sres = rnysql_list_tables("basel", $link);
Si = O;
whíle ($i < mysql_fetch _ro,v($res)) {
echo rnysql_ tablename($res, Si);
echo "<BR t>".,
Si++·,
Cuándo hacerlo
Hay ocasiones en las que, quizás por temas de seguridad o simple-
mente de lógica de negocios, una empresa guarda sus datos en distintas
bases. Por ejemplo, podría suceder que el sector de contaduría y el de
www.redusers.com «
120 4. PHP Y MYSQL
Cómo hacerlo
Acceder a dos o más bases de datos desde PHP es, por cierto, muy sen-
cillo e intuitivo si sabemos cómo acceder a una por vez. A continuación,
daremos algunos ejemplos:
<?php
Ilejemplo con dos bases de datos que están guardadas
Ilen diferentes servidores (netl y 127.0.0.1)
» www.redusers .com
PHP -s- MYSQL DESDE CERO 121
?>
<?php
Ilejemplo con dos bases de datos que están guardadas
Ilen el mismo servidor (abracadabra)
Ilestablecemos las conexiones
$conl = mysql_connect("abracadabra", "u", "p");
$con2 = mysql_connect("abracadabra", ''y'', "z");
?>
www.redusers.com «
122 4. PHP Y MYSQL
mysql_ close
Si abrirnos la conexión con mysql_connect, podemos cerrarla utilizando
la función mysql_ close, aunque debemos aclarar que este tipo de conexio-
nes se cierran en forma automática al terminar de ejecutarse cada página
PHP en la cual hayamos abierto una conexión previamente.
En cambio, la función no cerrará la conexión si esta fue abierta utilizan-
do la función mysql_pconnect. Su sintaxis es la siguiente:
mysql_ close(identificador);
<?php
Slink = mysql_ connect("localhost" , "u", "p");
ir (Slink) {
echo "Conexión Abierta!";
} else {
echo "~o puedo establecer la conexión";
}
if (Slink) {
Scerrar = mysql_ close($link);
ir (Scerrar) {
echo "Conexión cerrada!";
} else {
echo "No pude cerrar la Conexión!";
}
}
?>
» www.reduserscom
PHP .,. MYSQL DESDE CERO 123
<html>
<head>
<title>Autos.php!</title>
</head>
<body>
<?php
l/se establece una conexión con ~1ySQL
Slink = mysql_connect("localhost", "j", "m'') or die("Error en la conexión");
www.redusers.com «
124 4. PHP Y MYSQL
¿Por qué crear bases de datos o tablas desde PHP? Si distribuimos una aplicación a usua-
rios finales, esta se encargará de crear las diferentes estructuras para su funcionamiento.
» www.redusers .com
PHP -e- MYSQL DESDE CERO [!J;j3;fi 125
- e localhost
<>
......
_,_ . 't p
*r.~d
,,..,, •
o.t~tnOddlCd ')'1>'
,
• Otittop
JI 00wN0.ch
0._.
11
1
1 19.....
11 ..
,• .,. "'K"
1
1 111'1't.I ,..,
'd 1 11114 ""
h.~""", 1 1 ..... 'IH
• Ooc:","""",-, •. "4'"
-_
••"4'<1
ow.w
........
"',...._... .............
....... 1oor\.OOCXlO1 1
1"
Figura 4. Bases de datos autos almacenadaen el servidor .
Hemos aprendido cómo ejecutar sentencias SQL para definir la estructura de una base de
datos en MySQL: crear y eliminar bases de datos y tablas, establecer conexión y desconexión,
cómo listar tablas y bases de datos disponibles en el servidor, utilizar una o varias bases.
En el próximo capítulo nos alejaremos de las estructuras y las conexiones, y empezare-
mos a manipular los datos de la base.
www.redusers.com «
126 4. PHP Y MYSQL
Actividades
TEST DE AUTOE\' ALUACIÓ:K
EJERCICIOS PRÁCTICOS
» www.redusers .com
Utilizar S Len PHP
En este capítulo, haremos un recorrido por las distintas funciones que
PHP nos ofrece para realizar consultas de selección y de modificación
(el ingreso, la baja y la actualización de registros) .
..Insert 148
JI JI JI
128 5. UTILIZAR SQL EN PHP
Consultas de selección
El lenguaje de consulta SQL es sintético, muy potente y utilizado por dis-
tintos gestores de bases de datos. Cuando queremos realizar consultas de
selección (esto es, recuperar registros de una o más tablas), podemos obtener
millones de registros con solo una linea de código.
Veremos las distintas posibilidades que existen para extraer datos y
luego trabajar con ellos.
Selección simple
Nos referimos a consultas a una sola tabla por vez. Este tipo de consultas
son poco frecuentes en sistemas que tienen un diseño complejo.
SELECT * FROMTABLAl;
Consultas multitabla
Son consultas qlIe implican varias tablas a la vez, o sea, que recuperan
datos de varias fuentes. Son muy comunes. A lo largo del capitulo, vere-
mos cómo solucionar el problema que representa tener dos o más colum-
nas de varias tablas diferentes con el mismo nombre.
» www.redusers .com
PHP .,. MYSQL DESDE CERO 129
Subconsultas
Las sub consultas se implementaron en MySQL a partir de la versión 4.1, lo
cual potencia el motor de base de datos para selecciones de datos complejas.
rnysql_fetch_array
Esta función nos permite recuperar filas y acceder a los valores de cada
campo como si se tratase de una matriz. Su sintaxis es la siguiente:
www.redusers.com «
130 5. lJTILIZAR SQL EN PHP
Cuando se envía una consulta al servidor (por ejemplo, con mysql query
° lnysql_db_query)de bases de datos, el resultado devuelto por alguna de
estas funciones se denomina id_consulta.
Para recuperar los datos devueltos por la consulta (si es que los hay), una
de las funciones que podemos utilizar es mysql_fetch_array, a la cual se le pasa
como argumento el identificador de la consulta (en este caso id_consulta).
Cada vez que se llama a mysql_fetch_array,el puntero interno avanza
una fila. La primera vez que se la llama, se posiciona en la primera fila
(si es que hay primera fila). En el ejemplo que presentamos a continua-
ción cada vez que se llama a la función, se asignan a la matriz Sfila los
campos de la consulta $sql. Cuando no haya más filas, la matriz toma
el valor FALSE y el bucle WHILE termina.
<?php
$sql = "select * from tabla";
Sres = mysql_query($sql);
while (Sfila = mysql_fetch_array($res)) {
••••••
}
?>
Como esta función trata a cada fila como si fuera una matriz, el ar-
gumento tipojndice permite definir el tipo de índice. Las opciones son
MYSQL_ASSOC, MYSQL_NUNl y :tvlYSQL_BOTH.
La función mysql_fetch_array devuelve un array que contiene los valores de cada registro
devuelto por una consulta SQL. Este array es tratado por el lenguaje PHP como cualquier
otro, y es posible aplicar sobre él funciones como count, ínarray , sort y otras.
» www.redusers .com
PHP .,. MYSQL DESDE CERO 131
MYSQL_ASSOC
Se utiliza el nombre del campo (columna) como índice. Por ejemplo:
<?php
Ssql = "select el, c2 from alumnos";
Sres = mysql_query($sql);
?>
<?php
Ssql = "select * from alumnos";
Sres = mysql_query($sql);
?>
www.redusers.com «
l"?
:J_ [o;j3;;;3 5. UTILIZAR SQL ENPHP
MYSQL_NUM
Se usa el número del campo (columna) como índice, según el orden dado
en la consulta SQL. El Í11dice O corresponde al primer campo. Por ejemplo:
<?php
$sql = "select FFF, XXX,VYY from alumnos";
» www.redusers .com
PHP -s- MYSQL DESDE CERO 133
<?php
II estructura de la tabla alumnos:
II CREATE TABLE tl (
II XXX INT NOT NULL,
II FFF VARCHAR(12),
//YYYTEXT)
11) ENGINE=MYISAM;
?>
MYSQL_BOTH
Permite utilizar el número o el nombre del campo (columna) como
índice. Es COIUO utilizar NIYSQL_ASSOC y MYSQL_NUM al mismo tiempo.
Por ejemplo:
www.redusers.com «
134 5. UTILIZAR SQL EN PHP
<?php
Ssql = "select FFF, XXX,YYYfrom alumnos";
Sres = mysql_query(Ssql);
}
?>
rnysql_fetch_row
Esta función es como utilizar mysql_fetch_array con el argumento
tipo_indice igual a MYSQL_NUM, es decir, toma el número del campo
(columna) corno índice, según el orden dado en la consulta SQL. Por ejemplo:
» www.redusers .com
PHP + MYSQL DESDE CERO 135
<?php
$sql = "select a, b, e from tabla!";
Sres = mysql_query($sql);
mysql_fetch_object
Esta función trata a cada fila como si fuera un objeto y a cada campo
como si fuera una propiedad del objeto fila.
Es un error bastante común pensar que la función mysql numrows toma como índice
el número de columna según el orden de creación en la instrucción SQL create tableo
Esto no es así, no importa el orden de creación de la columna, sino el orden en el que
figura en la consulta de selección que se envía a J\tlySQL -generalmente a través de
mysql_query-, cuyo resultado es tomado por esta función.
www.reduaers.com «
136 5. UTILIZAR SQL EN PHP
Para recuperar los datos devueltos por la consulta (si es que los hay), una
de las funciones que se puede utilizar es mysqlfetch object , a la cual se le
pasa como argumento el identificador de la consulta (en este caso id_consulta).
Las opciones para el argumento tipo_indiceson otra vez MYSQL_ASSOC ,
MYSQL_NUM y MYSQL_BOTH. El argumento es opcional y, si se opta por no
incluirlo, se asume por defecto :tvIYSQL_ASSOC. Debe escribirse con letras
mayúsculas. Por ejemplo, si tenemos la tabla:
NBA
» www.redusers .com
PHP -e- MYSQL DESDE CERO 137
En PHP seria:
<?php
Ssql = "select * from l\""BA";
Sres = mysql_query(Ssql);
?>
1 Homero 38
4 Marge 37
5 Lisa 7
6 Bart 8
www.redusers.com «
138 5. UTILIZAR SQL EN PHP
1 Filadelfia 1200000
5 Phoenix 2000000
6 Seattle 300000
En PHP seria:
<?php
$sql = "select Codigol, TABLAl.Nombre, Tabla2.Nombre,
Edad from TABLAl, TABLA2 where Codigol=Codigo2";
Sres = mysql_query($sql);
<?php
$sql = "select Codigol, TABLA2.Nombre, Tablal.Nombre,
Edad from TABLAl, TABLA2 where Codigol=Codigo2";
Sres = mysql_query($sql);
» www.redusers .com
PHP .,. MYSQL DESDE CERO 139
<?php
Ssql = "select Codigol, TABLA2.Nombre as nom2, Tablal.Nombre
as noml, Edad from TABLAl, TABLA2 where Codigol=Codigo2";
Sres = mysql_quel)'($sql);
www.redusers.com «
140 5. UTILIZAR SQL ENPHP
mysql_fetch_field
Esta función no recupera los datos contenidos en una columna, pero
permite obtener información acerca de la estructura del campo y trabajar
con él como si fuera un objeto, de la siguiente manera:
» www.redusers .com
PHP -s- MYSQL DESDE CERO 141
<?php
Ssql = "select a , b , e from alumnos'" ,
Sres = mysql_query(Ssql);
while (Scampo = mysql_fetch_field(Sres)) {
echo $campo->name. "<br 1>";
echo $campo->table. "<br />";
echo $campo->type. "<br />";
}
www.redusers.com «
142 ttfj#;f3 5. UTILIZAR SQL EN PHP
mysql_data_seek
La sintaxis de la función es:
» www.reduserscom
PHP T MYSQL DESDE CERO 143
cod S nom s
1 PHP
2 Perl
3 Ruby
4 Python
<?php
$sql = "select nom_s from tablal";
Sres = mysql_query($sql);
II imprime:
IIPHP
JI Perl
II Ruby
II Python
II Rub_y
IIPHP
?>
www.redusers.com «
144 5. UTILIZAR SQL EN PHP
Número de registros
y campos devueltos
PHP provee funciones para obtener el número de filas y campos devuel-
tos luego de una consulta. Veremos una descripción de cada una de ellas.
mysql_Dum_rows
Esta función solo sirve para sentencias tipo SELECT. Devuelve el núme-
ro de filas de un resultado. Su sintaxis es:
Por ejemplo:
<?php
Ssql = "select * from tablal";
Sres = mysql_query(Ssql);
$numero_mas = mysql num rowsrsres);
» www.redusers .com
PHP .,. MYSQL DESDE CERO 145
mysql_affected_rowsüdentíñcador);
cod s nom s
1 Batman
2 Robín
3 Acertijo
4 Gatúbela
5 Alfred
La función mysqljíata jeek nos permite movemos entre registros. Además, puede ser útil
para no llamar más de una vez a una de las funciones mysql_fetch_array, mysqlfetch ob-
ject, mysqljfetchjissoc o mysqlfetchrow con la misma consulta a la base de datos. Si
mantiene la variable id_ consulta, también mantiene los datos devueltos por ella, y se puede
acceder a estos a través de mysql_data_seek o alguna de las funciones mysql_fetch.
www.redusers.com «
146 5. UTILIZAR SQL EN PHP
<?php
$con = mysql_connect("l68.22.22.3", "U", "p");
$sql = "update tablal set nom_ S = " where cod_ S > 2";
Sres = mysql_ query($sql);
<?php
$con = mysql_ connect("l68.22.22.3", "u", "p");
<?php
$con = mysql_ connect("l68.22.22.3", "u", "p");
» www.redusers .com
PHP .,. MYSQL DESDE CERO 147
rnysql_Durn_fields
Esta función, en lugar de entregar el número de filas devueltas por
la consulta, como hace mysql numrows , o modificadas, como hace
mysql_affected_rovvs, nos permite obtener el número de campos (columnas)
devueltos por la consulta. Su sintaxis es:
Por ejemplo:
<?php
//Devuelve el número de columnas de la tabla tablal
Soumero_campos = mysql_oum_fields(Sres);
<?php
//Devuelve 3 (la consulta devuelve 3 campos: a, b, e)
$numero_campos = mysql_oum_fields($res);
www.redusers.com «
148 5. UTILIZAR SQL EN PHP
Insert
Podemos realizar ingresos en una tabla a través de las funciones
rnysql_query o mysql db query ,pero PHP nos brinda otra función que puede
ser muy útil cuando se trabaja COll campos de autoincremento.
Campos autoincrementables
11ySQL nos permite insertar registros en una tabla evitando de forma
automática que un campo tome valores duplicados. Estos campos se lla-
man autoíncrementables y se definen en el momento de crear una tabla.
Por ejemplo:
<?php
$sql = "CREATE TABLE TI (";
$sql.= "codigo INT NOT NULL AUTO_INCREMENT, ";
$sql.= "descripcion VARCHAR(100) NOT NULL, ";
$sql .= "PRIJ.\IIARYKEY(codigo)";
$sql .= ")";
mysql_ query($sql);
» www.redusers .com
PHP .,. MYSQL DESDE CERO [!fjarfi 149
<?php
unysql_insert_id
Esta función devuelve el valor (no el número de fila) del último campo
autoincremental ingresado y debe llamarse inmediatamente después
del ingreso. Su sintaxis es la siguiente:
www.redusers.com «
150 5. UTILIZAR SQL EN PHP
mysql_insert_id(identificador);
<?php
//devuelve 5
?>
Delete
No existen funciones específicas para borrar tablas o registros,
o columnas de una tabla: todo esto se hace mediante las funciones
mysql query o la mysql dbquery . Observemos algunos ejemplos:
<?php
//borrar tablas
$sql = "DROP TABLE nombre_tabla";
mysql_ quel)'($sql);
» www.redusers .com
PHP -e- MYSQL DESDE CERO [!jOOj3;fi 151
<?php
$cbas = mysql_create_db("mibase") 01' DIE ("no se pudo crear la base");
Sbbas = mysql_ drop _db("mibase") 01' DIE ("no se pudo eliminar la base");
www.redusers.com «
152 5. lJTILIZAR SQL EN PHP
<?php
?>
LIBRO
FOTO L
-
Nombre de la imagen del libro
» www.redusers .com
PHP -s- MYSQL DESDE CERO [!Jf,3ifi 153
AL"TOR LIBRO
# COD A Código
~ del autor
# COD L Código
~ del libro
At.:TOR
~ACIO~_UIDAD
www.redusers.com «
154 5. UTILIZAR SQL EN PHP
Aulor I\ac;IG.all~.CI
~
/ f'...
Autor_Ubro
"V
Ubro
<?php
l/debe cambiar por los datos correctos de su
l/equipo/configuración!
$servidor = "localhost";
Susuarío = "root";
Spassword = '''';
$nombre_base = "libros";
» www.redusers .com
PHP .,. MYSQL DESDE CERO 155
<?php
www.redusers.com «
156 5. UTILIZAR SQL EN PHP
» www.redusers .com
PHP T MYSQL DESDE CERO [!JOOj3;fi 157
?>
La función mysqljíata jseek permite posicionarnos sobre algún registro particular de los
almacenados en un array de datos. Cada vez que llamamos a esta función, no hacernos
una consulta al servidor, sino que trabajamos con los datos almacenados en memoria de
la primera consulta, con lo que se obtiene una velocidad mayor de respuesta.
www.redusers.com «
158 5. UTILIZAR SQL EN PHP
• c:\w.mp\l>,n\mysql\mysqI5.S.8\bin\mysql.exe
(l¡o NttwD,k
» www.redusers .com
PHP -e- MYSQL DESDE CERO 159
<?php
ir (!include("./config.inc.php")) {
echo "no encuentro el archivo config.inc.php !!!!";
exit;
}
II select autores
Sres = mysql_query("select cod_a, concat_ \vs(', " ape_a, nom_a)
as nombre from autor order by ape_a ase, nom_a ase");
_
Sselect autores = '<select id="cbo _ autor" name="cbo _,autor">"
$select_autores .= '<optíon \'alue="O">Todos los autores</option>';
whíle ($fila = mysql_fetch_array($res» {
$select_autores .= '<option value = ,,, .$fila['cod _a']. "'>'.
uc\vords(strtolo\ver($fila['nombre']».'</optiou>';
}
$select autores .= '</select>';
// select libros
Sres = mysql_query("select cod_l, nom_1 from libro order by nom_1 ase");
_
Sselect libros = '<select id="cbo _ libro" name="cbo _,libro">"
Sselect_Ubros .= '<option ,'alue="O''>Todos los Libros</option>';
whíle (Sflla = mysql_fetch_array(Sres» {
Sselect_libros .= '<option value='" .SfIla['cod_I']. "'>'.
ucwordsistrtotowensñla ['nom_I']». '</option>';
}
Sselect libros .= '</select>';
// select nacionalidad
Sres = mysql_query("select cod_u, desc_u from na-
cionalidad order by desc_u ase");
_
$select uacionalidad = '<select id="cbo _ nacío-
nalidad" name="cbo _ nacionalidad">" ,
$select_nacionalidad .= '<option ,'alue="O">Todas las Nacionalidades </option>';
whíle ($fila = mysql_fetch_array(Sres» {
Sselect, nacionalidad .= '<option value='" .Sfila['cod _n']. "'>'.
www.redusers.com «
160 5. UTILIZAR SQL EN PHP
<btml>
<bead>
<title>buscar.pbp</title>
<style>
*{
font-family: Arial, Helvetica, sans-serif;
Iont-síze: 13px;
íont-weíght: bold;
color: #57534c;
text-decoration: none;
line-beigbt: 24px;
}
table {
border-top: lpx solid #57534c;
border-ríght: lpx solid #57534c;
}
td {
border-bottom: lpx solid #57534c;
border-Ieft: lpx solid #57534c;
}
</style>
</bead>
<body>
» www.redusers .com
PHP -s- MYSQL DESDE CERO 161
<tr>
<td> </td>
<td>
<form actten=vmestrar j'esultados.php" metbod="POST">
<table ceUpadding="4" ceUspacing="O''>
<tr>
<td>Seleccione Autor</td>
<td>
<?php echo $select_autores; ?>
<Itd>
<Itr>
<tr>
<td=Seleccíene Libro<ltd>
<td>
<?php echo $select_libros; ?>
<ltd>
<ltr>
<tI'>
<td>Ingrese I.S.B.~.<ltd>
<td><input type=vtext" id="txt _isbn" name="txt _isbn"><ltd>
</tr>
<tr>
<td>Seleccione Nacionalidad del Autor<ltd>
<td>
<?php echo $select_nacionalidad; ?>
</td>
<ltr>
<tr>
<td>Ingrese Palabra Clave-c/td>
<td><input type="text" id="txt_palabra _clave"
name="txt_palabra _ clave'e-otd>
</tr>
<tr>
<td> <ltd>
www.redusers.com «
162 5. UTILIZAR SQL EN PHP
</body>
</html>
ir ($_POST['nombre_control']) {
••••••
instrucciones
••••••
}
» www.redusers .com
PHP -e- MYSQL DESDE CERO 163
<?php
if (!include("./config.inc.php")) {
echo "no encuentro el archivo config.inc.php !!!!";
exit;
}
if (count($_POST» {
foreach ($ POST as $c => Sv)
$_POST[$c] = mysqlreal escape strtngtsv);
}
if ($_POST['cbo _autor'])
Ssql.=" and autor.cod_a = ".S_POST['cbo_autor'];
if ($_POST['cbo _libro'])
Ssql .= " and libro.cod _I = ".S_POST['cbo _libro'];
if (S_POST['cbo _nacionalidad'])
Ssql .=" and nacionalidad.cod_n = ".$_POST['cbo_nacionalidad'];
if ($_POST['txt_isbn'])
Ssql .= " and isbn_I = "'.S _POST['txt_isbn'].""';
www.redusers.com «
164 5. UTILIZAR SQL ENPHP
<html>
<head>
<title>mostrar _resultados. php</title>
<style>
*{
font-family: Arial, Helvefica, sans-sertf;
font-síze: 13px;
Iont-weíght: bold;
color: #57534c;
text-decoration: none;
líne-heíght: 24px;
}
table {
border-top: lpx solid #57534c;
border-ríght: lpx solid #57534c;
}
td {
border-bottom: lpx solid #57534c;
berder-leñ: lpx solid #57534c;
}
</style>
</head>
<body>
» www.redusers .com
PHP -e- MYSQL DESDE CERO 165
<?php
?>
</td>
<ztr>
<tr>
<td>
<?php
$c=O',
whíle ($f = mysql_ fetch _array($res)) {
www.redusers.com «
166 5. UTILIZAR SQL EN PHP
Sc++;
}
}
<ltable>
</td>
</tr>
<tr>
<td colspan="2"><a href "buscar.php">Volver al buscador<la><ltd>
</tr>
</table>
<lb o dy>
•
</html>
» www.reduserscom
PHP .,. MYSQL DESDE CERO [!6j3·fi 167
Favontes
Oesktop
... Oownloads
Oropbox
Recent Places
buscar contig.inc crear_estructura mostrar_resultad
os
.. Libreries
.J Oocuments
JI Music
~ Pictures
B Videos
~ Homegroup
... Computer
C. m059S1'M1F (C:)
, Network
Los datos que se guardan en una base están, por lo general, en continuo cambio. En este
capítulo, aprendimos a recuperar filas a través de consultas de selección, insertar datos,
modificarlos y borrarlos. Además consideramos las distintas funciones para recorrer el con-
junto de filas devueltas por una consulta y la manera de acceder a cada campo en particular;
por último, vimos un ejemplo completo de todo lo explicado.
www.redusers.com «
168 ttfj#;f3 5. UTILIZAR SQL EN PHP
Actividades
TEST DE AUTOE\' ALUACIÓ~
1 ¿Qué diferencia hay entre las funciones mysql_fetch_array y mysql fetch row ?
2 La función mysql num rows es equivalente a una función del lenguaje SQL,
¿cuál es esa función?
3 ¿Qué diferencia hay entre las funciones mysql_ num_rovvs ymysql_ affected _ro\vs ?
EJERCICIOS PRÁCTICOS
3 Cree una tabla y verifique a través del ingreso de registros que efectivamente
esta contiene un campo autoincremental.
» www.reduserscom
•
anejo e errores
Para lograr desarrollos robustos y estables, nos ayudará conocer
los errores frecuentes que podemos cometer o que suelen aparecer,
y aprender de ellos. Tanto PHP como MySQL nos brindan funciones
y opciones de configuración que nos permitirán tener un acceso
controlado y un entendimiento de los errores que puedan surgir
en nuestros futuros desarrollos.
JI JI JI
170 6. MANEJO DE ERRORES
error _reporting
Esta es una función muy útil para detallar los tipos de errores que es
posible mostrar en las páginas. Las opciones que nos brinda son:
» www.redusers .com
PHP -e- MYSQL DESDE CERO [!jOOj3;fi 171
En las distribuciones no solo de PHP, MySQL y Apache sino de muchas otras aplicaciones,
suelen incluirse archivos que contienen información acerca de los errores encontrados o
reportados por usuarios y todavía no solucionados. Incluso, si somos nosotros los que
encontramos algún error desconocido hasta el momento, podemos reportarlo a través de
un formulario o a una dirección de correo electrónico que figura en la misma distribución.
www.redusers.com «
172 6. MANEJO DE ERRORES
_
error reportíng =E _ ALL & ~E_ NOTICE
Mostrar todos los errores menos los errores no críticos y las advertencias:
error_reporting = E_ALL
En PHP existe una función con el mismo nombre que la directiva vista
anteriormente (errorreporting), que permite pasar por encima de lo que
está escrito en el archivo php.ini y utilizar el nivel de reporte de errores que le
demos a la función. Este valor permanecerá solo durante nuestra sesión,
luego se perderá y se seguirá usando el valor que figura en el php.ini ,
La sintaxis de la función es la siguiente:
Algunos lenguajes de programación traen junto con la ayuda del lenguaje sus entornos de
desarrollo. Como PHP no posee un entorno de desarrollo único, es posible que deba desear-
gatO la ayuda que proviene del sitio web de PHP, ya que tampoco viene junto con la versión
oficial. La ayuda está disponible en muchos formatos y para diversos sistemas operativos.
» www.redusers .com
PHP .,. MYSQL DESDE CERO 173
error_reporting(nivel);
• 1: E ERROR
• 2: E_ WARl'flNG
• 4: E PARSE
• 8: E_NOTICE
• 16: E_CORE_ERROR
• 32: E_CORE_ \VARNING
error_reporting(7);
display _errors
Para esta función obtenemos dos valores: 1 o O. Si se toma el valor verdade-
ro (1), al ocurrir un error se mostrará el mensaje correspondiente en pantalla.
www.redusers.com «
174 6. MANEJO DE ERRORES
r..i-... -
[11':"... ~ I~'" M....nJi4' ,tUwt;.' * ....
~~ ........
" ....,.. ..,.....rt. ..... r,w'_"
"
• In.,
0000: lot •• O
• """e' ~
() ,I~IO
~ .. ~
11........• "IL ... _.......... _..
I~ ,._ .. .' ................. ,...., S. ••f ........... L .~ ....... _... ..... I,.,_~
• In_
1
o (JO»>
0000.
mmlt o
....."1.... :0
1.... :10
» www.redusers .com
PHP -e- MYSQL DESDE CERO [!jOOj3;fi 175
log_errors
Cada servidor web, generalmente, mantiene en un archivo el registro
de todos los errores ocurridos. Estos errores pueden ser de cualquier
tipo, desde problemas al cargar módulos hasta de configuración.
Si queremos agregar a este archivo los errores que se producen en
las páginas PHP, deberemos configurar esta directiva para que 10 haga,
esta admite dos valores: 1 (verdadero) para activarla y O(falso) para
desactivarla. Su valor por defecto es O.
Tengamos en cuenta que habilitar o deshabilitar esta directiva no
modifica la conducta de display_errors ni viceversa. Puede mostrar u
ocultar los errores producidos al mismo tiempo que los guarda en el
archivo de errores del servidor, es decir, ambas directivas no son priva-
tivas ni están relacionadas de ninguna manera.
Si tenemos esta directiva habilitada, pronto -al cometer un error-
podremos ver en el archivo de errores líneas como las siguientes:
www.redusers.com «
176 6. MANEJO DE ERRORES
Estas marcan errores que tienen que ver con PHP. En el ejemplo ante-
rior, se puede ver que un usuario se intentó conectar a una base de datos
y 110 tenía permisos suficientes para hacerlo.
También registra errores de sintaxis, los parse errors , que ocurren cuan-
do escribimos de manera incorrecta lineas de código, cuando no cerramos
correctamente una cadena o cuando nos sobra o falta alguna llave para
cerrar o abrir módulos de código. Por ejemplo:
error_log
Desde esta directiva es posible configurar el nombre bajo el cual se
guardará el archivo que almacena los errores ocurridos. Podemos espe-
cificar también la ruta hacia el archivo, de manera de poder ubicarlo en
el directorio que nos resulte adecuado.
» www.redusers .com
PHP + MYSQL DESDE CERO 177
ignore_repeated_errors
Si configuramos esta directiva en el valor 1, PHP mostrará los errores
que se repiten solo una vez. Se asume que los errores, para considerar-
se reiterados, deben ocurrir en la misma línea yen el mismo archivo.
Veamos un ejemplo:
MySQL trae, junto con su distribución, una ayuda en formato HTML, que es realmente
muy extensa y completa. No solo proporciona una referencia de las funciones y las
características de la base de datos, sino también una serie de ejemplos y recomen-
daciones de mucha utilidad. Se puede descargar la ayuda en otros formaros desde el
sitio web de MySQL (www.mysql.com ).
www.redusers.com «
178 ttfj3¡fi 6. MA1\iEJO DE ERRORES
<BODY>
<?php
$cnx = mysql_pconnect('localhost', 'root', ") or DIE('Error en la conexion');
$db = mysql_ select_ db('basel ');
Es una buena costumbre tratar de resolver por nuestra cuenta los errores que come-
temos, pero en ocasiones nos será más beneficioso consultar la ayuda de PHP o de
l\!IySQL y no quedarnos estancados perdiendo tiempo para tratar de solucionar algún
inconveniente que se presente en nuestras aplicaciones.
» www.redusers .com
PHP .,. MYSQL DESDE CERO 179
Ii .ioll
1 0.0004 . moresl
0.0011 .....or~,1 15
\\·a.... : .)· .. I_... .,-Q .sp.dl •• ".1' 1 '. __ •• ', °...... (":\1ra.p..... ~rro... 1.P.... h.
Scack
errores I
15
\Vanli
•• : .)· .. I_.... ""() .spH1. a. "al' 1pa'HI".',Oaiv •• " C:\.... p\.... ~rror•• l.p..,o.II ••
Suck
H
)
jj trion
1 CIlOlesl
2 err or •• l 15
Dadas las condiciones que debe cumplir un error para considerarse repeti-
do, está claro que, como en el ejemplo, las líneas de error deberán estar den-
tro de ciclos o bucles ( for, while, do while, foreach, etc.). Puede resultar cómodo
tener esta directiva habilitada, porque nos facilitaría y aclararía de manera
considerable la visión de los errores cometidos en el momento de tenerlos en
la pantalla. Al acudir al código fuente de la aplicación y resolverlo, estaríamos
solucionando todas sus instancias. El comportamiento de ignore repeated errors
cambia según el valor de otra directiva llamada i gnore_repeated_source.
www.redusers.com «
180 6. MANEJO DE ERRORES
ignore_repeated_source
En apartados anteriores, cuando explicamos el funcionamiento de la di-
rectiva ignore_repeated_errors,dijimos que, para considerar un conjunto de
errores como repetidos, estos debían ubicarse en la misma línea del mismo
archivo. La directiva ignore_repeated_source modifica la definición de lo
que es en sí un error repetido con respecto a como 10 hace la directiva
ignore_repeated_errors. Cuando está activada, no tiene en cuenta el ori-
gen de los errores, es decir, el archivo en el que se produjeron. Así, si
cometemos un mismo error repetido que se reitera a su vez en más de
un archivo, solo veremos un mensaje de error.
Si mantenemos ignore_repeated_sourceen Oe ignorej epeated errors en 1,
PHP se comportará como se expuso en la sección ignorej'epeated errors .
Si mantenemos ignore repeatedsource en 1 e ignorerepeated errors en 1,
PHP se comportará como se expuso en la sección ignore_repeated_source .
track -errors
En PHP existe una variable cuyo nombre es php_errormsg(Sphp_errormsg),
que nos permite acceder al mensaje correspondiente al último error come-
tido, siempre y cuando la directiva track_errors esté habilitada. Suponiendo
esto último, veamos el siguiente código:
<BODY>
<?php
echo Smatríz -no-definida[34);
echo "<br>------------ ".,
» www.reduserscom
PHP T MYSQL DESDE CERO 181
</BODY>
<IHTML>
htmI -errors
Cuando esta directiva se encuentra deshabilitada, los errores se mues-
tran como mensajes en formato HTJ\1L. Supongamos el siguiente código:
<BODY>
www.redusers.com «
182 6. MANEJO DE ERRORES
<?pbp
mysql_ querytsvar);
?>
•
</BODY>
<IHTML>
btml errors = 00
_
docref root = "/manuaIPHPI"
Por último, indicamos la extensión que tienen los archivos del manual
que descargamos (HTML, TXT, etc.)
» www.reduserscom
PHP .,. MYSQL DESDE CERO 183
<BODY>
<?php
echo $matriz[34;
</BODY>
<IHTML>
www.redusers.com «
184 6. MANEJO DE ERRORES
<BODY>
<?php
echo $matriz[34;
</BODY>
<IHTML>
mysql_error
Esta función devuelve una descripción del último error cometido,
relacionado con MySQL. Su sintaxis es la siguiente:
» www.redusers .com
PHP + MYSQL DESDE CERO 185
mysql_error(identificador);
<?php
$id = mysql_connect("168.22.22.3", "u", "p");
echo mysql_ erren);
www.redusers.com «
186 6. MANEJO DE ERRORES
mysql_ errno
En NIySQL y en cualquier lenguaje de programación o aplicación, los
errores están catalogados y es posible identificarlos a través de un código.
Podemos conocer este código mediante la función mysql_errno. Su sintaxis
es similar a mysql_ error:
mysql , erroo(ideotificador);
<?php
$id = mysql, coooect("168.22.22.3", "u", "p");
echo mysqt errnot);
register globals
Utilizando register_globals = 011, PHP asume todas las variables como
globales y no podrá diferenciar entre los diferentes tipos de ellas (si usa
una variable en su script que tiene el mismo nombre de una variable de
sesión, PHP no podrá distinguirlas y las tratará como a una sola).
Para solucionar este problema y trabajar con register_globals = Off, PHP
nos ofrece los siguientes arrays:
• $ SERVER
• $ GET
• $ POST
» www.redusers .com
PHP .,. MYSQL DESDE CERO [!fjarfi 187
• $ COOKIE
• $ FILES
• $ ENV
• $ REQUEST
• $ SESSION
<l+paginalphp -->
<form action=pagina2.php method=POST>
<input type=text name=nombre>
<input type=submit>
</form>
<?php
//pagina2. php
?>
Los servidores web guardan un archivo con los errores producidos durante un perio-
do. Es recomendable revisar este archivo para observar comportamientos irregulares,
www.redusers.com «
188 ttfj3¡fi 6. MA1\iEJO DE ERRORES
• $_GET: almacena las variables pasadas por URL (por ejemplo, a través
de links o formularios con method=get). Quizás sea aquí donde se vea
de manera clara cuál es el problema de seguridad que supone usar
register_globals = 011. Supongamos que tenemos un script para auten-
tificar usuarios. Luego de un determinado proceso, si el usuario está
registrado, almacenamos en la variable usuario el valor registrado.
Al pasar la variable por URL, de acuerdo con la siguiente estructura:
http://ltV'fV'fv.misitioltveb.com?usuario=registrado ~utilizando
register_globals = 011 cualquiera estaría registrado, evitando el proceso
de registro (recordemos que PHP no necesita declarar las variables).
Habilitar
ladirectivaregister_globals puedeconvertirseenunatentación,yaquela mane-
ra deprogramaraplicacionessevuelvemásfácil;pero,tantopor cuestionesdeseguridad
comoporquecasinadiela habilita,serecomiendatenerladeshabilitada.
» www.redusers .com
PHP T MYSQL DESDE CERO 189
Como dato interesante, si trabajamos con los arrays que nos provee
PHP, nuestros scripts funcionarán tanto con register_globals = On como con
register_globals = Off. Podemos observar qué valor tiene la directiva register_
globals en su sistema de dos maneras: accediendo al archivo php.ini y bus-
cando la línea qtle contenga algo parecido a lo que muestra la figura 10.
Las innovaciones sobre las funcionalidades de las tablas incluyen avances respecto del
manejo y la descripción de los errores cometidos por los usuarios. Sin embargo, el trata-
miento de errores es una cuestión poco considerada por un alto porcentaje de usuarios.
www.redusers.com «
190 6. MANEJO DE ERRORES
"""'_III","_- óO 60 '09"l"_Olobo"
memort_1imII 12811 128101
_._"'''''1( no ~.'ue no\aJue
OU1PU1_D<tnonng 1 1
oulPULhandlet no ..-a/"e no"itue
poILINa_sI .. 81.1 811
p<OCIoion 1A 1A
[email protected]_C8che_slte 16K 16K
rOllpolh_C8Cho_ttl 120 120
reoill.'_lroc_lrov 011 011
regiIIO'..lIIobaI. 011 0tI
,eglllo,_long_a,noyo 011 Otf
repotL.memleakl en en
rOl>Ol\..lend_dobug en On
requelLorde, GP GP
~1._mOde oe OW
satt_mOdo_o.oC_dir rovstu« oova/ue
Snombre = S_GET[nombre);
ini_set("reoister
e _globals""1
" ").
» www.redusers .com
PHP -e- MYSQL DESDE CERO [!jOOj3;fi 191
perror
MySQL exhibe mensajes y códigos de error en muchos sistemas. Para obte-
ner más información o descripciones acerca de los errores podemos utilizar
el programa perror que viene junto con la distribución de MySQL.
Las descripciones de los errores pueden variar de un sistema operativo
a otro. Su sintaxis es la siguiente:
Manejo de excepciones
Una excepción es un suceso o evento que ocurre y que interrumpe la
ejecución normal de un programa. Puede ser por problemas en el hardware
de un equipo, errores de programación u otros.
Las excepciones están directamente ligadas a la programación orientada
a objetos. Cuando una excepción ocurre dentro de un método, este crea un
objeto que guarda información acerca de la excepción ocurrida. PHP puede
lanzar, intentar o capturar excepciones a través de los bloques try, catch y
throw. Si la excepción no es capturada, se producirá un error fatal, y PHP
mostrará un mensaje para referir esta situación. Las excepciones son co-
munes en lenguajes como Java o C++ y se implementaron en PHP versión 5.
www.redusers.com «
192 ttfi#·f, 6. MANEJO DE ERRORES
Actividades
TEST DE AUTOEV ALuACIÓ~
EJERCICIOS PRÁCTICOS
» www.redusers .com
Administración
ases atos
Mientras desarrollamos nuestras aplicaciones, cumplimos el rol de
administrador de servidor web, servidor de bases de datos, programador
de aplicaciones, llSllariO y más. Pero, cuando trabajamos en un sistema
real, las tareas se vuelven más específicas. En este capitulo, entenderemos
la naturaleza y el rol de los administradores de bases de datos .
JI JI JI
2 APÉl.\'DICE. lillMlNISTRAC¡ÓN DE BASES DE DATOS
Si bien este libro está destinado al trabajo con bases de datos MySQL, cuando en este
capítulo hablamos de las tareas fundamentales y a la vez comunes de los administradores
de bases de datos ,no hacemos referencia específica a ninguna base de datos, puesto
que las tareas son independientes de la elección.
» www.redusers .com
PHP -e- MYSQL DESDE CERO 3
• Mantener la información.
• Monitorear las actividades de los usuarios. Controlar el acceso.
• Generar estadísticas e informes.
• Probar nuevos productos que posiblemente se instalarán en el sistema.
Sistema de privilegios
MySQL cuenta con un sistema.de privilegios que tiene como fin princi-
pal validar la conexión de un usuario y otorgarle determinados permisos
-operaciones- sobre bases de datos, tablas y columnas.
Uno de los permisos que pueden concedérsele a un usuario es
la posibilidad de ejecutar determinadas instrucciones (SELECT, INSERT,
www.redusers.com «
4 APÉNDICE. ADMINISTRACIÓN DE BASES DE DATOS
Tabla user
La tabla user contiene información sobre cada uno de los usuarios:
desde qué máquina puede acceder al servidor MySQL hasta su clave y
sus diferentes permisos. La estructura de la tabla user y la descripción
de cada campo es la siguiente:
» www.redusers .com
PHP .,. MYSQL DESDE CERO [!fjarfi 5
TABLA USER
T CA.\fPO T DESCRIPCIÓN
www.redusers.com «
6 APÉNDICE .. 1U)MI1'llSTRAC¡ÓN DE BASES DE DATOS
Tabla host
La tabla host contiene información sobre las máquinas que podrán
acceder al servidor, así como de las bases de datos y sus diferentes per-
misos. Permite definir permisos globales para máquinas con acceso a
las bases de datos del servidor. Contiene los mismos campos, a excep-
CiÓ11 de user, que la tabla db, que veremos a continuación. Su estructura
y la definición de los campos es la siguiente:
» www.redusers .com
PHP -s- MYSQL DESDE CERO [!Jf,3ifi 7
TABLA HOST
T CA.'fPO T DESCRIPCIÓN
www.redusers.com «
8 APÉNDICE .. .<illMlNISTRAC¡ÓN DE BASES DE DATOS
Tabla db
La tabla db permite especificar permisos para bases de datos indivi-
duales. Las columnas host, db y user sirven para especificar el host desde
el que puede acceder el usuario, el nombre de usuario a quien se le reco-
nocen permisos y la base de datos a la que se van a aplicar los permisos,
respectivamente. Los permisos indicados en esta tabla solo se aplican a
la base de datos identificada en la columna db.
TABLADB
» www.redusers .com
PHP .,. MYSQL DESDE CERO 9
TABLES PRIV
T CA.\fPO T DESCRIPCIÓN
www.redusers.com «
10 APÉNDICE .. 1illMI1'llSTRAC¡ÓN DE BASES DE DATOS
COLUMNS PRIV
» www.redusers .com
PHP + MYSQL DESDE CERO 11
Jerarquías de acceso
Como se dijo antes, al recibir un intento de conexión, 11ySQL compara
los datos ingresados con los que figuran en la tabla user. Si hay coinci-
dencia -es decir, si en la tabla hay una fila que contenga el mismo user,
password y host-, se autoriza el acceso a ese usuario.
Ante cada instrucción SQL generada por un usuario conectado, 11ySQL
vuelve a consultar la tabla user, esta vez para verificar si tiene permisos
para ejecutar esa instrucción. Si los tiene, la instrucción se ejecuta; si no
los tiene se pasa a consultar la tabla db para comprobar si tiene permisos
La tarea de un administrador de bases de datos puede parecer lejana para los usuarios
de sistemas o desarrolladores de aplicaciones. Sin embargo, cuando se tiene la necesi-
dad de administrar un servidor web, por ejemplo, cosa no tan extraña por estas épocas,
se deberán poner en práctica algunas de las tareas y métodos utilizados por aquellos.
www.reduaers.com «
12 APÉl.\'DICE. lillMlNISTRAC¡ÓN DE BASES DE DATOS
Comando grant
Permite crear nuevos usuarios y modificar sus permisos.
» www.redusers .com
PHP -e- MYSQL DESDE CERO 13
Si quisiéramos dar ciertos permisos sobre una tabla de una base de datos
en particular para un usuario que se conecta desde una máquina específica:
www.redusers.com «
14 APÉNDICE. ADMIN1STRAC¡ÓN DE BASES DE DATOS
mysql> grant select (coll, col2, col3) on nombre _base.nombre _tabla to lucas
@nombre_host identified by 'blablabla';
ñ.í.c r-os oLt \lindo ..1S Lüe i-s Ion 6.1. ?600J
COPYl~iy},t 2009 (c) Micl'O!>oft Co r-po r-a t Lon . All l'iy}'l5 r-e s e r-v e d,
: ,U s e r-s '<Pr-anc .is co )cd e: '\.\/dmp'.J in 'mys. q 1'mys. q 15 . S .8 '<bin
C:'\',anp'hin'\.nysql'l1lys.qlS _S_U'bin)nysql -ll pipo -px
\,/clcone to t he NySQL mnn Lt o r-, COflfllc."ll\:';' und ~lit)1 ; u.' 'y.
VOlt1' NySQL connect ion id Le 9
~el'vel' vel'siorl: S.5.S-log NySQL Cornnllnity SCl'vel' (GPL)
COPYl-igl,t (c) 2~~~~ 2~1~,Ol'acle and/oJ' its affiliates. AIl l'ig),ts l·esel·ued.
r-ec Je .is a r-eq i s t e r-ed t r-adene i-k of Or-ac Ie Co r-po r-ac i o n endvo r- Lt s
<;tffili~,tc~;_ Otile." '1C\nt!S tTl(\y }JC t r-a derae r-k s of t hc r- r-e s pc c c ivc
í
oone r-s ,
Type ')lelp;' Ol" ',11' fOl" 11elp. Iype "e' to cleal" tlle eUl".~ent inpl,t statement.
Las distintas tareas que cumple lID administrador de bases de datos, desarrolladas
en este mismo capítulo, se volvieron, a través de los distintos avances producidos,
tan importantes que incluso desde hace algún tiempo a esta parte se dictan cursos y
carreras para especializarse en esta área.
» www.redusers .com
PHP -s- MYSQL DESDE CERO [!fi3;fi 15
LISTADO DE PRIVILEGIOS
T CA;\IPO T DESCRIPCIÓN
ALL Permite al usuario obtener todos los privilegios, excepto grant option
(Ver al final de la tabla).
www.redusers.com «
16 APÉl.\'DICE. lillMlNISTRAC¡ÓN DE BASES DE DATOS
Comando revoke
Su sintaxis y forma de uso es similar a grant, pero en vez de dar
privilegios, los quita. Por ejemplo:
Implementar en los sistemas un área para el control y seguimiento de las actividades de los
usuarios que ingresan en nuestro sitio puede ser interesante desde el punto de vista esta-
dístico y económico, y también lo será en el aspecto referido a la seguridad. Por ejemplo,
podríamos evitar el acceso al sitio a usuarios conflictivos o que intenten realizar algún daño.
» www.redusers .com
PHP + NIYSQL DESDE CERO 17
Quita todos los privilegios sobre todas las bases de datos disponibles
en el servidor al usuario jason, desde donde sea que se conecte.
www.reduaers.com «
18 APÉNDICE. ADMINISTRACIÓN DE BASES DE DATOS
Gestión de usuarios
Para gestionar nuestros usuarios, en la consola de MySQL contamos con
diferentes herramientas que veremos a continuación.
Baja de usuarios
Se pueden quitar usuarios borrando las entradas correspondientes en la
tabla user, o bien, limitando sus privilegios a través del comando revoke, visto
anteriormente en este mismo capitulo. Utilizando revoke no se eliminará al
usuario, pero se logrará que se mantenga totalmente inoperante e inofensivo.
» www.redusers .com
PHP + MYSQL DESDE CERO 19
www.redusers.com «
20 APÉNDICE. ADMINISTRACIÓN DE BASES DE DATOS
Actividades
TEST DE AUTOEV ALUACIÓI\
5 ¿Es posible crear dos usuarios con el mismo nombre y distintas contraseñas?
Haga la prueba.
EJERCICIOS PRÁCTICOS
1 Ingrese al servidor como usuario ROOT y dé de alta a un usuario llamado PIPO que
tenga permiso para realizar consultas SELECT sobre todas las base de datos.
Dele una contraseña y permítale acceder solo desde el host local ( localhosn
2 Conéctese a una base de datos como usuario PIPO e intente borrar una tabla.
4 ¿Hay en su servidor algún usuario con permiso para acceder a algún dato, cuyo
nombre sea Marty? Responda a esta pregunta mediante una consulta SQL.
» www.redusers .com
CON
PHP+MySQL desde cero
En este libro nos centraremos en el uso del lenguaje de programación
PHP en conjunto con una potente herramienta: el gestor de bases
de datos MySQL. Desde el inicio veremos la teoría y puesta en
práctica de bases de datos, continuaremos con el aprendizaje de
las facilidades que nos provee el lenguaje y aprenderemos cómo
potenciar nuestras aplicaciones con el gestor.
.""'"'" •
¡ ¡ .)'it'I1IIY ,"tJ;~ ~
~ ~
ISBN 978-987-1949-66-3
.
REDUSERS.com PROFESOR E:\TLDffiA
En nuestro sitio podrá encontrar noticias Ante cualquier consulta técuíca
relacionadas y también participar relacionada con el libro, puede
RU de la comunidad de tecnologia más
importante de América Latina.
contactarse con nuestros expertos:
profesorjjredusers.com.