Tabla de Contenidos

10.5 Base de datos

En este tema por fin vamos a tratar el tema del acceso a la base de datos. Todo lo que vamos a explicar en este tema es la parte mínima de mi otro curso de Hibernate con Spring.

Es decir que aquí vamos a hacer lo mínimo necesario para que funcione la capa de acceso a datos pero la forma correcta está explicada en el Curso de Hibernate con Spring. Obviamente no lo explicamos aquí ya que es material para un curso entero.

Así que si este tema queda poco claro, recomiendo leerse el curso de Hibernate con Spring, especialmente la unidad de Arquitectura aunque en diversas ocasiones voy a hacer referencias al curso de Hibernate con Spring por si algo no queda claro del todo.

MySQL

Lo primero es preparar la base de datos, para ello debes seguir los siguientes pasos:

El script anterior creará una única tabla con los datos del seguro médico:

PlantUML Graph

Recuerda crear el usuario “seguromedico” con contraseña “seguromedico”

Modelo de datos

La tabla “seguromedico” que acabamos de crear se mapeará a las siguientes clases Java que serán las que tengan los datos que se obtienen/envian de/a la base de datos.

PlantUML Graph

Como vemos las clases son iguales al sistema de clases que teníamos en el modelo de JavaScript , por lo que transformando la clase SeguroMedico a JSON obtendremos exactamente el JSON que necesitamos para nuestra aplicación de AngularJS

Interfaz DAO

¿Recuerdas que al tratar con la librería de JSON llamada Jackson encapsulamos su funcionamiento bajo un interfaz?. Para el acceso a la base de datos vamos a hacer lo mismo por ello vamos a crear el interfaz SeguroMedicoDAO.

El siguiente diagrama en UML muestra los métodos y relaciones del interfaz:

PlantUML Graph

Lo interesante de la clase SeguroMedicoDAO es que todos los métodos lanzan una excepción llamada BussinessException. Esta excepción tiene una propiedad que es una lista de objetos BussinessMessage. Esta última clase la vimos en el tratamiento de errores de los servicios REST.

Es decir que cuando cualquiera de los métodos quiera comunicarnos que ha habido algún problema para procesar la petición 1) se lanzará una BussinessException que contendrá la lista de problemas que ha habido. Ya veremos como hacerlo en el siguiente tema.

La clase que implementa el interfaz SeguroMedicoDAO es SeguroMedicoDAOImplJDBC que realiza el acceso a la base de datos usando directamente el API de JDBC.

PlantUML Graph

Ahora le tenemos que decir a Spring que existe esa clase para que pueda inyectarla cuando sea necesario, por ello en el fichero applicationContext.xml tendremos que añadir la siguiente línea:

    <bean class="es.cursohibernate.basedatos.persistencia.impl.SeguroMedicoDAOImplJDBC" />

Ya que la clase SeguroMedicoDAOImplJDBC se encontrará en el paquete es.cursohibernate.basedatos.persistencia.impl.

Ahora en los controladores de Spring ya podremos hacer lo siguiente

    @Autowired
    SeguroMedicoDAO seguroMedicoDAO;

Y por lo tanto tener acceso al DAO sin estar acoplados a una implementación concreta del DAO en el código del controlador. Lo que nos permitiría en un futuro cambiar la implementación a Hibernate, a JPA, etc. sin tener que tocar nada de los controladores.

Pool de conexiones

Ya hemos configurado la base de datos y creado todas las clases Java necesarias, pero nos falta una última cosa por hacer: Configurar el pool de conexiones.

Dicho de forma que se entienda rápido , el pool de conexiones lo podríamos ver simplemente como una cache de conexiones para tener acceso rápidamente a una conexión cada vez que llega una petición al servidor web. Es decir es una funcionalidad delservidor Web que nos ayuda a mejorar el rendimiento de la aplicación.

La forma de activar el pool de conexiones es añadiendo al fichero META_INF/context.xml dentro del tag Context el siguiente fragmento:

    <Resource
        type="javax.sql.DataSource"
        auth="Container" 
        name="jdbc/seguromedico" 
        driverClassName="com.mysql.jdbc.Driver"
        url="jdbc:mysql://localhost:3306/seguromedico"
        username="seguromedico" 
        password="seguromedico"

        maxActive="100" 
        maxIdle="30" 
        maxWait="10000"
        validationQuery="SELECT 1 FROM dual"
     />

Si quieres una información detalla sobre el pool de conexiones e información sobre como se configura y utiliza, la tienes en Pool de conexiones.

Ejemplo

El ejemplo de esta unidad es exactamente lo que acabamos de contar pero en un nuevo proyecto llamado “basedatos”.

Para aclarar mas el ejemplo vamos a hacer un pequeño resumen de los cambios en el proyecto respecto al ejemplo del tema anterior:

Se muestra ahora la imagen con la estructura del proyecto:

Los paquetes Java empiezan por es.cursohibernate.basedatos ya que este proyecto es para configurar todo lo relativo a la base de datos. No confundirlo con los paquetes para acceso a datos que aqui se llaman persistencia

Por último hemos modificado el controlador para usar ahora como ejemplo la clase del modelo SeguroMedico en vez de la clase Usuario, haciendo los siguientes cambios:

El código Java de SeguroMedicoController es el siguiente:

@Controller
public class SeguroMedicoController {
    
    @Autowired
    private JsonTransformer jsonTransformer;
    
    @Autowired
    SeguroMedicoDAO seguroMedicoDAO;
    
    @RequestMapping(value = {"/SeguroMedico"})
    public void prueba(HttpServletRequest httpRequest, HttpServletResponse httpServletResponse) throws Exception {
        SeguroMedico seguroMedico=seguroMedicoDAO.get(1);
        String jsonSeguroMedico=jsonTransformer.toJson(seguroMedico);
        
        httpServletResponse.getWriter().println(jsonSeguroMedico);
    }
}

Si ahora navegamos a la URL http://localhost:8084/basedatos/api/SeguroMedico se mostrará lo siguiente:

{"idSeguro":1,"nif":"12345678Z","nombre":"Patata","ape1":"Cano","edad":41,"sexo":"H","casado":true,"numHijos":3,"embarazada":false,"coberturas":"oftalmologia":true,"dental":false,"fecundacionInVitro":false},"enfermedades":{"corazon":true,"estomacal":false,"rinyones":false,"alergia":true,"nombreAlergia":"Acaros"}}

Referencias

1) que no un error de programación