COMPARTE ESTE ARTÍCULO

En la programación Java, el acceso a datos es una parte crucial para la mayoría de las aplicaciones empresariales. Una manera popular de gestionar este acceso es mediante el uso del patrón DAO (Data Access Object), que permite manejar las operaciones de base de datos de una manera organizada y modular. Aunque generalmente se usa una interfaz para definir las operaciones de DAO, en algunos casos se puede optar por una sola clase sin interfaces para simplificar el diseño, especialmente en proyectos más pequeños o para propósitos educativos.

Este artículo explora cómo implementar un DAO sin interfaz en Java, usando una clase TrabajadorDAO para manejar la creación, lectura, actualización y eliminación (CRUD) de registros de trabajadores.

¿Qué es DAO?

El patrón Data Access Object (DAO) es un patrón de diseño que facilita el acceso a datos en una aplicación. Aísla la lógica de acceso a datos de la lógica de negocio, permitiendo que los desarrolladores manejen las operaciones de base de datos sin mezclar el código de la lógica de negocio. Usualmente, DAO se implementa con una interfaz que define los métodos CRUD, y una clase concreta que implementa esta interfaz. Sin embargo, en algunos proyectos, puede ser más conveniente implementar el DAO directamente en una clase concreta, como veremos en este ejemplo.

Ventajas de Usar un DAO sin Interfaz

El uso de una clase DAO sin interfaz puede ofrecer algunas ventajas en ciertos contextos:

  • Simplicidad: Al no tener que definir e implementar interfaces, el código es más directo y fácil de seguir, ideal para proyectos pequeños o estudiantes que recién se inician en el concepto de DAO.
  • Fácil de modificar: La clase DAO concreta es fácil de modificar y extender, ya que no depende de una interfaz. Esto permite realizar cambios en la estructura de los métodos sin restricciones.
  • Menos código: No se requiere código adicional para interfaces, lo que puede reducir el tamaño y complejidad del proyecto.

Ejemplo de Implementación: Gestión de Trabajadores con TrabajadorDAO

A continuación, se muestra cómo implementar un DAO sin interfaz para manejar una lista de trabajadores. La clase TrabajadorDAO contiene todos los métodos necesarios para realizar operaciones CRUD en una base de datos MySQL.

Clase Trabajador

Esta clase representa a un trabajador, con atributos básicos como id, nombre, puesto y salario.

public class Trabajador {
    private int id;
    private String nombre;
    private String puesto;
    private double salario;

    public Trabajador(int id, String nombre, String puesto, double salario) {
        this.id = id;
        this.nombre = nombre;
        this.puesto = puesto;
        this.salario = salario;
    }

    // Getters y Setters
    public int getId() { return id; }
    public void setId(int id) { this.id = id; }
    public String getNombre() { return nombre; }
    public void setNombre(String nombre) { this.nombre = nombre; }
    public String getPuesto() { return puesto; }
    public void setPuesto(String puesto) { this.puesto = puesto; }
    public double getSalario() { return salario; }
    public void setSalario(double salario) { this.salario = salario; }
}

Clase TrabajadorDAO

La clase TrabajadorDAO implementa directamente los métodos CRUD para agregar, leer, actualizar y eliminar trabajadores de la base de datos.

import java.sql.*;
import java.util.ArrayList;
import java.util.List;

public class TrabajadorDAO {
    private final String url = "jdbc:mysql://localhost:3306/mi_base_de_datos";
    private final String user = "usuario";
    private final String password = "contraseña";

    // Método para agregar un trabajador
    public void agregarTrabajador(Trabajador trabajador) {
        try (Connection conn = DriverManager.getConnection(url, user, password)) {
            String sql = "INSERT INTO trabajadores (id, nombre, puesto, salario) VALUES (?, ?, ?, ?)";
            PreparedStatement ps = conn.prepareStatement(sql);
            ps.setInt(1, trabajador.getId());
            ps.setString(2, trabajador.getNombre());
            ps.setString(3, trabajador.getPuesto());
            ps.setDouble(4, trabajador.getSalario());
            ps.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    // Método para obtener un trabajador por ID
    public Trabajador obtenerTrabajador(int id) {
        Trabajador trabajador = null;
        try (Connection conn = DriverManager.getConnection(url, user, password)) {
            String sql = "SELECT * FROM trabajadores WHERE id = ?";
            PreparedStatement ps = conn.prepareStatement(sql);
            ps.setInt(1, id);
            ResultSet rs = ps.executeQuery();
            if (rs.next()) {
                trabajador = new Trabajador(
                        rs.getInt("id"),
                        rs.getString("nombre"),
                        rs.getString("puesto"),
                        rs.getDouble("salario")
                );
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return trabajador;
    }

    // Método para obtener todos los trabajadores
    public List<Trabajador> obtenerTodosLosTrabajadores() {
        List<Trabajador> trabajadores = new ArrayList<>();
        try (Connection conn = DriverManager.getConnection(url, user, password)) {
            String sql = "SELECT * FROM trabajadores";
            Statement stmt = conn.createStatement();
            ResultSet rs = stmt.executeQuery(sql);
            while (rs.next()) {
                Trabajador trabajador = new Trabajador(
                        rs.getInt("id"),
                        rs.getString("nombre"),
                        rs.getString("puesto"),
                        rs.getDouble("salario")
                );
                trabajadores.add(trabajador);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return trabajadores;
    }

    // Método para actualizar un trabajador
    public void actualizarTrabajador(Trabajador trabajador) {
        try (Connection conn = DriverManager.getConnection(url, user, password)) {
            String sql = "UPDATE trabajadores SET nombre = ?, puesto = ?, salario = ? WHERE id = ?";
            PreparedStatement ps = conn.prepareStatement(sql);
            ps.setString(1, trabajador.getNombre());
            ps.setString(2, trabajador.getPuesto());
            ps.setDouble(3, trabajador.getSalario());
            ps.setInt(4, trabajador.getId());
            ps.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    // Método para eliminar un trabajador
    public void eliminarTrabajador(int id) {
        try (Connection conn = DriverManager.getConnection(url, user, password)) {
            String sql = "DELETE FROM trabajadores WHERE id = ?";
            PreparedStatement ps = conn.prepareStatement(sql);
            ps.setInt(1, id);
            ps.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

Conclusión

El patrón DAO en Java es una herramienta poderosa para manejar el acceso a datos de manera organizada y eficiente. En el caso de proyectos simples o educativos, puede ser beneficioso implementar el DAO sin interfaces, en una sola clase que gestione todas las operaciones CRUD necesarias. En este ejemplo, TrabajadorDAO contiene métodos para agregar, obtener, actualizar y eliminar registros de trabajadores en una base de datos MySQL. Aunque este diseño es sencillo, en proyectos más complejos o escalables, podría ser más adecuado utilizar interfaces para permitir una mayor flexibilidad y mantenimiento del código.

Este enfoque ofrece una buena introducción al patrón DAO, a la vez que ilustra una implementación directa y sin interfaces para quienes buscan comprender los conceptos básicos de acceso a datos en Java.


¿QUÉ TE HA PARECIDO EL ARTÍCULO? Danos tu opinión al final de la página.
Deja tu comentario y ayúdanos a crecer.


¡SÍGUENOS EN TUS REDES FAVORITAS!
AYUDANOS A CRECER Y QUE LLEGUEMOS A TODAS LAS PERSONAS QUE NOS NECESITANA. SÍGUENOS EN TUS REDES.
Entra AQUÍ y elíge donde seguirnos. 

 

 


NUESTRAS ÚLTIMAS PUBLICACIONES

INSTAGRAM

TIKTOK


 …Y PRONTO MUCHAS MÁS

AYUDANOS A CRECER Y A LLEGAR A TODAS LAS PERSONAS QUE NOS NECESITAN.

Contenido restringido

Acceso de usuarios existentes
   
Registro de un nuevo usuario
*Campo necesario

Categories:

Tags:

Comments are closed

Estado de acceso
ESTADO DE ACCESO
TRADUCTORES
COMPARTENOS
error: CONTENIDO PROTEGIDO