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
- 🧪 Simulacro de Examen – Programación II VJ1208 (Simulacro 5 – Estilo PDF)
- 🧪 Simulacro de Examen – Programación II VJ1208 (Sin estructuras dinámicas)
- ¿Qué son los Stack, Push, Pop y Peek en C#?
- 🧪 Simulacro de Examen – Programación II VJ1208 (Versión Simplificada)
- 🧪 Simulacro de Examen – Programación II VJ1208 (Nivel Básico – 1 hora)
- 🧭 ¿Qué es la distancia Manhattan en C#? Ejemplo práctico
- Simulacro de Examen – Programación II (versión “larga”)
- Podcast Academia SanRoque – Historias de España – 001: Edad media en la península ibérica.
- El Arte de Inventar Idiomas: Entre la Genialidad y la Farsa
ELIGE TU RED FAVORITA Y SÍGUENOS.
AYUDANOS A CRECER Y A LLEGAR A TODAS LAS PERSONAS QUE NOS NECESITAN.
Contenido restringido
Comments are closed