Entradas

Mostrando entradas de junio, 2026

Try-with-resources: una solución para manejar recursos en Java

  Cuando trabajamos con bases de datos en Java, es común abrir múltiples recursos como Connection , PreparedStatement y ResultSet . El problema es que, si no se cierran correctamente, pueden producirse fugas de memoria o saturación de conexiones. Para resolver esto, Java incorporó desde la versión 7 la estructura try-with-resources , una forma más segura y limpia de manejar recursos que deben cerrarse automáticamente. ¿Qué es try-with-resources? Es una extensión del bloque try que permite declarar recursos dentro de paréntesis. Estos recursos se cierran automáticamente al finalizar el bloque, incluso si ocurre una excepción. Ejemplo sin try-with-resources Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; try { conn = ConexionBD.getConnection(); ps = conn.prepareStatement("SELECT * FROM mascotas"); rs = ps.executeQuery(); while (rs.next()) { System.out.println(rs.getString("nombre")); } } catch (SQLException e)...

Creando una clase de conexión a MySQL en Java

  Cuando comencé a aprender Java, una de las primeras tareas fue conectarme a una base de datos MySQL. Para ello, normalmente se crea una clase encargada de centralizar la configuración de la conexión y entregar objetos Connection al resto de la aplicación. Un ejemplo simple es el siguiente: package com.egga.appvet.includes; import java.sql.DriverManager; import java.sql.SQLException; import java.sql.Connection; public class ConexionBD { private static final String URL = "jdbc:mysql://localhost:3306/AppVet"; private static final String USER = "tuusuario"; private static final String PASS = "tupassword@"; public static Connection getConnection() throws SQLException { return DriverManager.getConnection(URL, USER, PASS); } } En este ejemplo se definen tres constantes: URL: dirección de la base de datos MySQL. USER: usuario utilizado para conectarse al servidor. PASS: contraseña del usuario. El método getConnection() devuel...