Conexión a bases de datos con PHP y MySQL

Conoce los fundamentos de conexión a bases de datos MySQL desde PHP

En esta clase del curso aprenderás a conectar y manejar bases de datos MySQL utilizando PHP. La conexión a bases de datos es una habilidad fundamental en el desarrollo web, ya que permite almacenar y recuperar información de manera eficiente. En esta clase, te guiaremos a través de los conceptos básicos de PHP y MySQL, y te mostraremos cómo establecer una conexión segura y realizar consultas SQL para interactuar con la base de datos.

Introducción a PHP y MySQL

PHP y MySQL son dos tecnologías ampliamente utilizadas en el desarrollo web. PHP es un lenguaje de programación del lado del servidor que se utiliza para generar contenido dinámico en páginas web. Por otro lado, MySQL es un sistema de gestión de bases de datos relacionales que permite almacenar y recuperar datos de manera eficiente.

Aprende los conceptos básicos de PHP y MySQL

Antes de profundizar en la conexión a bases de datos con PHP y MySQL, es importante comprender los conceptos básicos de cada tecnología. PHP utiliza una sintaxis similar a la de otros lenguajes de programación como C o Java, pero está especialmente diseñado para la generación de contenido web. Por otro lado, MySQL utiliza una estructura de tablas para almacenar datos y se basa en el lenguaje SQL (Structured Query Language) para interactuar con la base de datos.

Beneficios de utilizar PHP y MySQL juntos en el desarrollo web

La combinación de PHP y MySQL ofrece varios beneficios para el desarrollo web. Algunas de estas ventajas incluyen:

  • - Escalabilidad: PHP y MySQL son altamente escalables, lo que significa que pueden manejar grandes cantidades de datos y un alto volumen de tráfico en aplicaciones web.

  • - Flexibilidad: PHP y MySQL son tecnologías flexibles y se pueden integrar fácilmente con otras herramientas y frameworks, lo que permite el desarrollo ágil de aplicaciones web.

  • - Conexión y manejo sencillo de MySQL con PHP


Conexión a bases de datos con PHP y MySQL

En esta sección, aprenderemos cómo establecer una conexión a una base de datos MySQL utilizando PHP y cómo manipular y administrar datos en MySQL mediante PHP.

Cómo establecer una conexión a una base de datos MySQL utilizando PHP

Para establecer una conexión a una base de datos MySQL con PHP, necesitamos utilizar la extensión MySQLi (MySQL Improved). Esta extensión proporciona una interfaz orientada a objetos para interactuar con MySQL desde PHP.

A continuación, se muestra un ejemplo de cómo establecer una conexión a una base de datos MySQL utilizando PHP:

<?php
$servername = "nombre_servidor";
$username = "nombre_usuario";
$password = "contraseña";
$dbname = "nombre_base_de_datos";

// Crear una conexión
$conn = new mysqli($servername, $username, $password, $dbname);

// Verificar la conexión
if ($conn->connect_error) {
    die("Conexión fallida: " . $conn->connect_error);
}

echo "Conexión exitosa a la base de datos MySQL";
?>

Métodos para manipular y administrar datos en MySQL mediante PHP

Una vez que hemos establecido la conexión a la base de datos MySQL, podemos utilizar diferentes métodos proporcionados por la extensión MySQLi para manipular y administrar datos en la base de datos.

Algunos de los métodos más comunes incluyen:

Uso de query para ejecutar consultas SQL en la base de datos:

<?php

$query = "SELECT * FROM usuarios";
$result = $conn->query($query);
if ($result) {
    // Procesar los resultados
    while ($row = $result->fetch_assoc()) {
        // Acceder a los datos de cada fila
        echo $row['nombre'] . " " . $row['email'] . "<br>";
    }
}

Uso de prepare y execute para preparar y ejecutar consultas con parámetros<:/p>

<?php

$query = "SELECT * FROM usuarios WHERE id = ?";
$stmt = $conn->prepare($query);
$id = 1;
$stmt->bind_param("i", $id);
$stmt->execute();
$result = $stmt->get_result();
if ($result) {
    // Procesar los resultados
    while ($row = $result->fetch_assoc()) {
        // Acceder a los datos de cada fila
        echo $row['nombre'] . " " . $row['email'] . "<br>";
    }
}
$stmt->close();

Uso de fetch para recuperar una fila de resultados como un array asociativo, numérico o ambos:

<?php

$query = "SELECT * FROM usuarios";
$result = $conn->query($query);
if ($result) {
    // Recuperar una fila como array asociativo
    $row = $result->fetch(PDO::FETCH_ASSOC);

    // Recuperar una fila como array numérico
    $row = $result->fetch(PDO::FETCH_NUM);

    // Recuperar una fila como array asociativo y numérico
    $row = $result->fetch(PDO::FETCH_BOTH);
}

Uso de fetch_assoc para recuperar una fila de resultados como un array asociativo:

<?php

$query = "SELECT * FROM usuarios";
$result = $conn->query($query);
if ($result) {
    // Recuperar una fila como array asociativo
    $row = $result->fetch_assoc();
    echo $row['nombre'] . " " . $row['email'];
}

Uso de fetch_row para recuperar una fila de resultados como un array numérico:

<?php

$query = "SELECT * FROM usuarios";
$result = $conn->query($query);
if ($result) {
    // Recuperar una fila como array numérico
    $row = $result->fetch_row();
    echo $row[0] . " " . $row[1];
}

Uso de fetch_array para recuperar una fila de resultados como un array asociativo y numérico:

<?php

$query = "SELECT * FROM usuarios";
$result = $conn->query($query);
if ($result) {
    // Recuperar una fila como array asociativo y numérico
    $row = $result->fetch_array();
    echo $row['nombre'] . " " . $row[1];
}

Estos son solo algunos ejemplos de los métodos disponibles. A lo largo de esta clase, exploraremos más ejemplos prácticos de cómo utilizar estos métodos para interactuar con la base de datos MySQL desde PHP.


Consultas SQL en PHP y MySQL

En esta sección, aprenderemos a realizar consultas SQL utilizando PHP y MySQL. Las consultas SQL nos permiten recuperar, insertar, actualizar y eliminar datos de la base de datos.

Realización de consultas SQL utilizando PHP y MySQL

Para realizar consultas SQL utilizando PHP y MySQL, utilizaremos el método query proporcionado por la extensión MySQLi. Este método nos permite ejecutar consultas SQL en la base de datos.

A continuación, se muestra un ejemplo de cómo realizar una consulta SELECT utilizando PHP y MySQL:

<?php

<?php
$sql = "SELECT * FROM usuarios";
$result = $conn->query($sql);

if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        echo "Nombre: " . $row["nombre"] . "<br>";
        echo "Email: " . $row["email"] . "<br>";
        echo "<br>";
    }
} else {
    echo "No se encontraron resultados.";
}
?>

En este ejemplo, estamos realizando una consulta SELECT para recuperar todos los registros de la tabla "usuarios". Luego, utilizamos un bucle while para iterar sobre los resultados y mostrar la información en el navegador.

Ejemplos prácticos de consultas SELECT, INSERT, UPDATE y DELETE

Además de las consultas SELECT, también podemos realizar consultas INSERT, UPDATE y DELETE utilizando PHP y MySQL.

A continuación, se muestran ejemplos prácticos de cada tipo de consulta:

Consulta INSERT:

<?php
$sql = "INSERT INTO usuarios (nombre, email) VALUES ('Juan', '[email protected]')";
if ($conn->query($sql) === TRUE) {
    echo "Registro insertado correctamente.";
} else {
    echo "Error al insertar el registro: " . $conn->error;
}
?>

Consulta UPDATE:

<?php
$sql = "UPDATE usuarios SET email='[email protected]' WHERE id=1";
if ($conn->query($sql) === TRUE) {
    echo "Registro actualizado correctamente.";
} else {
    echo "Error al actualizar el registro: " . $conn->error;
}
?>

Consulta DELETE:

<?php
$sql = "DELETE FROM usuarios WHERE id=1";
if ($conn->query($sql) === TRUE) {
    echo "Registro eliminado correctamente.";
} else {
    echo "Error al eliminar el registro: " . $conn->error;
}
?>

Estos son solo algunos ejemplos de consultas SQL que se pueden realizar utilizando PHP y MySQL. A lo largo de esta clase, exploraremos más ejemplos prácticos y casos de uso comunes.

Mejores prácticas para la gestión de datos en PHP y MySQL

Aquí hay algunas mejores prácticas a considerar al gestionar datos en PHP y MySQL:

  • - Utiliza consultas preparadas (prepared statements) en lugar de concatenar directamente los valores en las consultas SQL. Las consultas preparadas ofrecen protección contra ataques de inyección SQL y mejoran la seguridad de tu aplicación.

  • - Valida y sanitiza los datos ingresados por los usuarios antes de utilizarlos en consultas SQL. Esto ayuda a prevenir ataques de inyección SQL y asegura la integridad de los datos almacenados en la base de datos.

  • - Utiliza índices adecuados en las tablas de MySQL para mejorar el rendimiento de las consultas. Los índices permiten una búsqueda más rápida y eficiente de los registros.

  • - Realiza copias de seguridad periódicas de la base de datos para evitar la pérdida de datos en caso de fallos o errores.

Estas son solo algunas de las prácticas recomendadas al gestionar datos en PHP y MySQL. A medida que adquieras más experiencia, descubrirás más técnicas y enfoques para mejorar la eficiencia y seguridad de tus aplicaciones.


Conclusión

En esta clase, hemos explorado cómo conectar y manejar bases de datos MySQL utilizando PHP. Hemos aprendido los conceptos básicos de PHP y MySQL, cómo establecer una conexión segura a la base de datos, realizar consultas SQL y gestionar eficientemente los datos.

La conexión a bases de datos es una habilidad esencial en el desarrollo web, y PHP y MySQL son una combinación poderosa para interactuar con bases de datos de manera efectiva. Con estos conocimientos, podrás desarrollar aplicaciones web dinámicas y escalables que almacenen y recuperen datos de manera eficiente.

Espero que hayas encontrado útil esta clase y que te sientas más cómodo trabajando con PHP y MySQL. ¡Sigue practicando y explorando nuevas posibilidades para ampliar tus habilidades de desarrollo web!


Ejercicios Resueltos

  • Ejercicio 1

    Supongamos que tenemos una tabla llamada "productos" con los siguientes campos: id, nombre, precio y categoría. Queremos realizar una consulta que nos devuelva todos los productos de la categoría "Electrónica".

    <?php
    $categoria = "Electrónica";
    
    $sql = "SELECT * FROM productos WHERE categoria = '$categoria'";
    $resultado = $conn->query($sql);
    
    if ($resultado->num_rows > 0) {
        while ($row = $resultado->fetch_assoc()) {
            echo "ID: " . $row["id"]. " - Nombre: " . $row["nombre"]. " - Precio: " . $row["precio"]. "<br>";
        }
    } else {
        echo "No se encontraron productos en la categoría de Electrónica.";
    }
    ?>
    
  • Ejercicio 2

    Supongamos que queremos actualizar el precio de un producto específico en nuestra tabla "productos". Aquí está el código para realizar esta actualización en PHP y MySQL:

    <?php
    $id_producto = 1;
    $nuevo_precio = 99.99;
    
    $sql = "UPDATE productos SET precio = $nuevo_precio WHERE id = $id_producto";
    
    if ($conn->query($sql) === TRUE) {
        echo "El precio del producto se actualizó correctamente.";
    } else {
        echo "Error al actualizar el precio del producto: " . $conn->error;
    }
    ?>
  • Ejercicio 3

    Supongamos que deseamos eliminar un producto de nuestra tabla "productos" en base a su id. Aquí está el código para realizar esta eliminación en PHP y MySQL:

    <?php
    $id_producto = 2;
    
    $sql = "DELETE FROM productos WHERE id = $id_producto";
    
    if ($conn->query($sql) === TRUE) {
        echo "El producto se eliminó correctamente.";
    } else {
        echo "Error al eliminar el producto: " . $conn->error;
    }
    ?>