sábado, 20 de abril de 2013

MODULO IV



Bases de Datos con Tecnología Java

Les comparto mi diseño de la base de datos de mi proyecto de un sistema para la administración de una farmacia.




Tabla de sustancia_activa

Esta tabla contiene el id y el nombre de la sustancia activa que compone a un medicamento, es un catálogo de sustancias activas que se relaciona la tabla nombre_comercial.

Tabla de nombre_comercial

Contiene un identificador único y el nombre comercial de un medicamento, esta tabla se relaciona con la tabla sustancia_activa.

Tabla dosificacion

Esta tabla contiene un catálogo  de tipos de dosis con la que se debe de aplicar el medicamento y un identificador único.

Tabla forma_farmaceutica

Esta tabla contiene un catálogo con la descripción de la disposición externa que se da a los medicamentos para facilitar su administración.

Tabla laboratorio

Esta tabla contiene un catálogo de nombre de laboratorios que fabrican los medicamentos.

Tabla proveedor

Catálogo de las empresas a las que se les compra el medicamento para su venta en la farmacia.

Tabla compra

Contiene la fecha de compra y la cantidad de medicamentos comprados.

Tabla venta

Esta tabla contiene la fecha en la que se vendió un medicamento así como la cantidad de medicamentos que se vendieron.

Tabla medicamento

Contiene un catálogo de medicamentos con los detalles de esta, contenido total, fecha de caducidad, nombre comercial, dosificación, laboratorio, sustancia activa, forma farmacéutica y precio. Esta tabla es la base del funcionamiento del sistema para poder conocer los detalles de un medicamento y poder venderlo o comprarlo.

Tabla compra_medicamento
Aquí se van relacionar las tablas compra con medicamento, esta tabla contendrá un registro de cada uno de las compras en base a las claves o id de estas tablas, con esta tabla podremos saber cuántos medicamentos de cada tipo se han comprado la farmacia

Tabla venta_medicamento
En esta tabla así como en compra_medicamento se van a registrar cada una de las transacciones de salida de medicamentos,  se podrá generar una consulta de ventas y compras para un medicamento y así sabremos cual ha sido los medicamentos más vendidos y en qué periodo de tiempo para poder generar futuras compras.

API utilizada
Se utilizó la biblioteca de clases java.io para realizar inserciones en la base de datos, es decir para poder actualizar los catálogos de medicamento, se utilizó la clase Scanner para poder leer los datos de teclado y guardarlos.
Cuando se implemente el sistema se tiene pensado cargar los datos mediante una lista de Excel que tiene el “cliente” para evitar llenar los registros uno por uno.
Para visualizar los datos de cada una de las tablas se utilizó javax.swing desde eclipse con el plugin CloudGarden's Jigloo. Se utilizaron JList y JTable para poder mostrar los datos en un JFrame, en un futuro se tiene planeado utilizar HTML para mostrar estos datos desde un JSP.

Estructura de mi proyecto separando las capas del sistema en modelo vista y servicios o controlador.

  Data Acces Object

Metodo para insertar proveedores a la base de Datos:

public Proveedor saveProveedor(Proveedor proveedor) {
        Connection conn = null;
        PreparedStatement pstmt = null;
        try {
       
                // Creación del DataSource
                BasicDataSource dataSource = new BasicDataSource();
                dataSource.setDriverClassName("com.mysql.jdbc.Driver");
                dataSource.setUsername("root");
                dataSource.setPassword("admin");
                dataSource.setUrl("jdbc:mysql://localhost:3306/farmamedic");
               
                // Se obtiene la conexión
                conn = dataSource.getConnection();
                // BEGIN TRANSACTION
                conn.setAutoCommit(false);
               
                String sql = "INSERT INTO proveedor " +
                        "(nombre) " +
                        "VALUES (?)";
                pstmt = conn.prepareStatement(sql);
                pstmt.setString(1, proveedor.getNombre());
                pstmt.executeUpdate();
                conn.commit();
               
            return proveedor;
               
        }catch(SQLException ex)
        {
            try{
                System.out.println(ex.getMessage());
            conn.rollback();
            }catch (SQLException e1)
            {
                // TODO Auto-generated catch block
                e1.printStackTrace();
            }
        }
        finally
        {
           
            try {
                pstmt.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            try {
                conn.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        return proveedor;
    }


Se maneja el uso de transacciones que en caso de algún error o excepción genera un rollback en las instrucciones sql ejecutadas.También se cierran los flujos con la base de datos y se capturan las excepciones que pueden generar.

En el paquete model se encuentran las clases que contienen la estructura de cada una de las tablas de la base de datos para su manipulación como objetos(métodos get y set).

public class Proveedor implements Serializable {

    private static final long serialVersionUID = 2189161461106174085L;
    private int clave;
    private String nombre;
    public int getClave() {
        return clave;
    }
    public void setClave(int clave) {
        this.clave = clave;
    }
    public String getNombre() {
        return nombre;
    }
    public void setNombre(String nombre) {
        this.nombre = nombre;
    }

}

El paquete de servicios contiene las clases para interatuar con el modelo para pasar los datos a la vista en caso de que así se requiera, ejemplo:


public class ProveedorServiceImpl implements ProveedorService {

    @Override
    public Proveedor addProveedor(Proveedor proveedor) {
        if(proveedor==null)
        {
           
            throw new BusinessException("Proveedor requerido");
        }
        ProveedorDao proveedorDao=new ProveedorDaoImpl();
        return proveedorDao.saveProveedor(proveedor);
    }

    @Override
    public Proveedor updateProveedor(Proveedor proveedor) {
        ProveedorDao proveedorDao=new ProveedorDaoImpl();
        return proveedorDao.updateProveedor(proveedor);
    }

    @Override
    public void deleteProveedor(Proveedor proveedor) {
        ProveedorDao proveedorDao=new ProveedorDaoImpl();
        proveedorDao.deleteProveedor(proveedor);
    }

    @Override
    public List<Proveedor> getProveedor( ) {
        return new ProveedorDaoImpl().findProveedor();
    }

}
Las vistas contienen las clases para interactura con el usuario en caso de agregar medicamentos, actualizar catálogos o borrarlos, utilicé java.io y javax.swing.

Interfaz  de listado de proveedores:

 Código para vender medicamentos con java.io:

public class VentaForm {

    /**
     * @param args
     */
    public static void main(String[] args) {
      
        Scanner sc=new Scanner(System.in);
        Venta venta=new Venta();
        VentaService ventaServicio=new VentaServiceImpl();
      
        System.out.println("Venta de medicamentos");
      
        System.out.println("Ingresa le fecha de venta");
        String fecha=sc.next();
      
        System.out.println("Ingresa la cantidad");
        int cantidad=sc.nextInt();
      
        venta.setFecha_venta(fecha);
        venta.setCantidad(cantidad);
        ventaServicio.addVenta(venta);
        System.out.println("Venta Realizada");
        sc.close();
    }

}

 

1 comentario:

  1. Muy buen trabajo Mireya.

    Recuerda que cuando se realiza el modelado de la base de datos (y también en programación), es necesario definir convenciones de nombrado, del modelo que presentas creo que hizo falta que definieras una convención ya que las propiedades de las entidades no siguen un patrón de nombrado, para la siguiente ocasión toma esto en cuenta.

    Presentaste de una forma bastante adecuada el avance de tu proyecto, ya que es bastante concisa y clara.

    ResponderEliminar