Curso de Java y Aplicaciones Web Facultad Politécnica – U.N.A. Ing. Esteban Ramírez Persistencia Java.

Slides:



Advertisements
Presentaciones similares
Fundamentos de Base de Datos
Advertisements

FUNDAMENTALS OF THE JAVA PROGRAMMING LANGUAGE
2010Ing. de Sistemas II Persistencia en EJB3 Pasos para crear entity beans.
JEE Entity Enterprise Beans Herencia. 2009Ing. de Sistemas II2 Herencia y Polimorfismo en Entity Beans Los Entity Beans son clases Java comunes que soportan.
Las aplicaciones requieren datos persistentes
Acceso a Bases de Datos con Java
Introducción a HIBERNATE
CLASIFICACIÓN DE CLASES Orientación a objetos UNIVERSIDAD DEL VALLE DEL FUERTE Análisis y Diseño Orientado a Objetos Cañedo Encinas Fernando Onorat. Ingeniería.
Programación Orientada a Objetos
Curso de Java Capitulo 7: Conceptos sobre poo Profesor:
Introducción a LAS Bases de Datos
JAVA PERSISTENCE API (jpa)
COLEGIO DE BACHILLERES PLANTEL 13 XOCHIMILCO-TEPEPAN MATERIA:TIC EQUIPO:23 PRESENTACION: BASE DE DATOS ALUMNAS: Velazquez Corona Elsa Ponciano Antonio.
UML 1.4 Peter Emerson Pinchao Solis.
“SISTEMA DE PASANTÍAS PARA LA FACULTAD DE INGENIERÍA
Unidad 6: EJB 3.0 David Rodríguez 1.
Aplicación de diseño de clases y generación de código, orientado hacia la arquitectura multicapas y el mapeo objeto/relacional Juan Timoteo Ponce Ortiz.
Teoría de los lenguajes Proyecto SIGU Equipo Nº3 Universidad Argentina J. F. Kennedy Sede: Don Bosco Integrantes: Irene Arias Fernández Mariana Pacheco.
Lenguaje de consulta de Hibernate
Curso de Java y Aplicaciones Web
Oracle, orientado a objetos
JAVA Persistence API (JPA)
Programación por capas: Capa de Clases
Programación Orientada a Objetos en Java
DIAGRAMA DE CLASE.
BASES DE DATOS ORIENTADAS A OBJETO
Enterprise Java Beans Rubén Trujillo Sept-Dic 2008.
Tema 3 J2EE Java Database Connectivity Temas Selectos de Cómputo Grupo 912.
Tema 7: Polimorfismo Antonio J. Sierra. Índice Introducción. Sobrecarga de métodos. Objetos como parámetros. Paso de argumentos. Devolución de objetos.
Java Persistance API JPA.
UNIDAD I Conceptos Básicos.
SIA Sistema Integrado de Admisión
SQL Básico Prof. Nelliud D. Torres.
Desarrollo de Aplicaciones Utilizando Java Edición Empresarial – JEE6
Bases de datos en la Web n Las bases de datos permiten almacenar de una forma estructurada y eficiente toda la información de un sitio web n Ventajas –Proporcionar.
Componentes sintácticos
Diseño de una base de datos Zavaleta Nolasco Karina
Diseñando la arquitectura de aplicaciones empresariales. Acceso al SQL Server.- Autenticación de usuario:
SQL (Structured Query Language / Lenguaje de consulta estructurado)‏
Mapeo Objeto – Relacional JPA – Java Persistence Api
Enterprise Java Beans. EJBs Beans gestionados por un contenedor del servidor de aplicaciones para gestionar el acceso a recursos (bases de datos, colas.
Frameworks de Persistencia Java Prof. Ing. Esteban Ramírez
Programación en Visual Basic Lección #8: SQL Por Antonio F. Huertas.
CONSULTAS SENCILLAS A LA BASE DE DATOS
Bases de Datos Sql.
Introducción a UML DIAGRAMA DE CLASES Departamento de Informática
El modelo de análisis tiene como objetivo generar una arquitectura de objetos que sirva como base para el diseño posterior del sistema. Dependiendo del.
Bienvenidos. Desarrollo de Aplicaciones I Lic. Alfonso Felipe Lima Cortés
TEMA 9: DIAGRAMA DE CLASE EN UML
COLEGIO DE BACHILLERES PLANTEL 13 XOCHIMILCO-TEPEPAN MATERIA:TIC EQUIPO:21 PRESENTACION: BASE DE DATOS ALUMNAS: Adán Millán Sánchez.
LENGUAJE ESTRUCTURADO DE CONSULTAS
Lenguaje Estructurado de Consulta
Universidad del Cauca – FIET – Departamento de Sistemas CAPITULO 0 Introducción.
Conceptos. -Programación orientada a eventos. -Instancias de clase. -Atributo de los objetos. -Método main, get y set. -Ejemplo de la declaración de.
Bases de Datos Modelo Relacional.
MSSQL SERVER CURSO BÁSICO 1. CONCEPTOS BASICOS DE SQL. DESCRIPCIÓN DEL CURSO. Sesión 3: Índices Uso, Creación, Tipos, Eliminación LENGUAJE DE CONSULTAS.
Acceso a Datos Erick López Ovando Licenciado en Informática.
SQL es el lenguaje de comunicación entre el programa cliente y programa servidor; Oracle es un programa servidor, en el que está la base de datos propiamente.
Sistemas de Información I
Unidad 6. Tema 4. Lenguaje de consultas SQL
Servicios Web Conjunto de aplicaciones o de tecnologías con capacidad para interoperar en la Web. Estas aplicaciones o tecnologías intercambian datos entre.
ACCESO A DATOS EN ASP.NET Controles de origen de datos Controles enlazados a datos.
Programación orientada a objetos La programación orientada a objetos o POO (OOP según sus siglas en inglés) es un paradigma de programación que usa objetos.
Motor de Persistencia - Mapeos. El mapeo Objeto - Relacional es un acercamiento entre el Modelo de Objetos y el Modelo Relacional, para poder persistir.
Patricia López & Julio Medina Computadores y Tiempo Real Santander, 2013 G80 - Advanced Computation 1 Generación de Código con BOUML.
Programación en Java Introducción a Java. Reseña histórica Surge en 1991 por Sun Microsystems Desarrollado para electrodomésticos Se buscaba un código.
Concepto de Tipo y Subtipo Diseño e Implementación Fundamentos de Programación Departamento de Lenguajes y Sistemas Informáticos Unidad Didáctica 10 Versión.
Programación I Clases. Paradigma POO La programación Orientada a objetos (POO) es una forma programar, más cercana a como expresaríamos las cosas en la.
Softlogia S.R.L. Formación de Recursos Humanos Hibernate Core Instructor: Martin R. Baspineiro.
Programación en Java Introducción a Java. Reseña histórica Surge en 1991 por Sun Microsystems Desarrollado para electrodomésticos Se buscaba un código.
Transcripción de la presentación:

Curso de Java y Aplicaciones Web Facultad Politécnica – U.N.A. Ing. Esteban Ramírez Persistencia Java

Objetivos Hibernate JPQL Ciclo de vida de entidades Frameworks Java persistence api - JPA Curso de Java y Aplicaciones Web

Java Persistence API Se llama “persistencia” de los objetos java a su capacidad para guardarse y recuperarse desde un medio de almacenamiento. La persistencia en Base de Datos relacionales se suele implementar mediante el desarrollo de funcionalidad específica utilizando la tecnología JDBC - Java Database Connectivity o mediante frameworks que automatizan el proceso a partir de mapeos (conocidos como Object Relational Mapping, ORM). JPA (Java Persistence Api) Proporciona un estándar para gestionar datos relacionales en aplicaciones Java SE o Java EE, de forma que además se simplifique el desarrollo de la persistencia de objetos java. Es una API de persistencia de POJOs (Plain Old Java Object). Es decir, objetos simples que no heredan ni implementan otras clases excepto Object. 3

Frameworks – JPA providers 4

5

Motores de Bases de datos 6

7

FRAMEWORK JPAFRAMEWORK Provider 8

JPA: Java Persistence API El mapeo objeto-relacional (es decir, la relación entre entidades Java y tablas de la base de datos, queries con nombre, etc) se realiza mediante anotaciones en las propias clases de entidad. No se requieren ficheros descriptores XML. También pueden definirse transacciones como anotaciones anotación 9

JPA: Java Persistence Mapeo Lógico Mapeo Físico Mapeo Físico Permiten describir modelo de objeto, asociaciones de clase, etc Describen esquemas físicos de base de datos, tablas, columnas, @JoinColumn, etc 10

JPA: Arquitectura El siguiente diagrama muestra la relación entre los componentes principales de la arquitectura de JPA: 11

JPA: Excepciones 12

JPA: entidad Una entidad es un objeto de dominio de persistencia. Normalmente, una entidad representa una tabla en el modelo de datos relacional y cada instancia de esta entidad corresponde a un registro en esa tabla 13

JPA: public class Empleado implements Serializable { private Long id; //setId getId public Empleado(){ … } La clase debe poseer en su encabezado la anotación La clase debe poseer un constructor PUBLIC,PROTECTED sin argumentos Ningún método o variables de instancias deben ser declaradas como FINAL La clase no debe ser declarada como FINAL Si una instancia de una entidad entra en entornos remotos,debe implementar la interfaz SERIALIZABLE Los atributos persistentes de la clase deben ser declarados como PRIVATE, PROTECTED y solo deben ser accesadas por los métodos de la clase 14

JPA: entidad El estado persistente de una entidad puede ser accesible a través de variables de instancia a la entidad o bien a través de las propiedades de estilo de JavaBean (Setters and Getters). Los campos o propiedades pueden tener asociados los siguientes tipos Java: Tipos primitivos de Java (int,long,double,etc) java.lang.String Otro tipo de objeto serializable, incluyendo: Wrappers de tipos primitivos en Java (Integer,Long,Double,etc) java.math.BigInteger java.math.BigDecimal java.util.Date java.util.Calendar java.sql.Date java.sql.Time java.sql.TimeStamp User-defined serializable types byte [ ] Byte [ ] char [ ] Character [ ] Tipos enumerados (Enumeration) Otras entidades y/o colecciones de entidades 15

JPA: entidad Campos Persistentes Propiedades Persistentes 16

JPA: entidad Las colecciones posibles son: java.util.Collection java.util.Set java.util.List java.util.Map Las variables genéricas de estos tipos también pueden ser utilizadas 17

JPA: entidad - Cada entidad se relaciona con una sola instancia de otra entidad. Donde la ambas se referencian por la misma llave Una entidad, puede estar relacionada con varias instancias de otras Múltiples instancias de una entidad pueden estar relacionadas con una sola instancia de otra entidad. Esta multiplicidad es lo contrario a la relación uno a muchos. Usado también como si fuera una relación En este caso varias instancias de una entidad pueden relacionarse con múltiples instancias de otras entidades. 18

JPA: entidad @Table(name=“usuarios”) public class Usuario implements Serializable { …//username private Persona persona; //setter and public class Persona implements Serializable { …//id nombre apellido fechaNacimiento } 19

JPA: entidad - Cada entidad se relaciona con una sola instancia de otra entidad. Donde la ambas se referencian por la misma llave Una entidad, puede estar relacionada con varias instancias de otras Múltiples instancias de una entidad pueden estar relacionadas con una sola instancia de otra entidad. Esta multiplicidad es lo contrario a la relación uno a muchos. Usado también como si fuera una relación En este caso varias instancias de una entidad pueden relacionarse con múltiples instancias de otras entidades. 20

JPA: entidad @Table(name=“paises”) public class Pais implements Serializable { private Set ciudades; } 21

JPA: entidad - Cada entidad se relaciona con una sola instancia de otra entidad. Donde la ambas se referencian por la misma llave Una entidad, puede estar relacionada con varias instancias de otras Múltiples instancias de una entidad pueden estar relacionadas con una sola instancia de otra entidad. Esta multiplicidad es lo contrario a la relación uno a muchos. Usado también como si fuera una relación En este caso varias instancias de una entidad pueden relacionarse con múltiples instancias de otras entidades. 22

JPA: entidad @Table(name=“ciudades”) public class Ciudad implements Serializable private Pais pais; } 23

JPA: entidad - Cada entidad se relaciona con una sola instancia de otra entidad. Donde la ambas se referencian por la misma llave Una entidad, puede estar relacionada con varias instancias de otras Múltiples instancias de una entidad pueden estar relacionadas con una sola instancia de otra entidad. Esta multiplicidad es lo contrario a la relación uno a muchos. Usado también como si fuera una relación En este caso varias instancias de una entidad pueden relacionarse con múltiples instancias de otras entidades. 24

JPA: entidad @Table(name=“estudiantes”) public class Estudiante implements Serializable private Set cursos; } 25

Ciclo de vida de una entidad 26

Operaciones con entidades 27

28 Ciclo de vida de una entidad

Operaciones con entidades 29

Operaciones con entidades 30

Operaciones con entidades Base de datos Flush() Refresh() flush() Sincroniza los datos de una entidad y los hace persistentes en la base de datos. refresh() Contrario al flush(),este método vuelve a cargar los datos originales de la base de datos a la entidad. 31

JPA: Arquitectura javax.persistance Persistance.xml EntityManagerFactory EntityManager Persistance Unit Name Persistance Library(Provider) Entities Provider settings 32

JPA – Estructura de Proyecto Archivo de configuración del motor de persistencia persistence,xml 33

JPA – Estructura de Proyecto Clase Persona.java Tabla en base de datos 34

JPA – Estructura de Proyecto Creación de la clase Persona.java 35

JPA – Estructura de Proyecto Creacion del EMF (EntityManagerFactory) 36

Java Persistence Query Language (JPQL) 37

38 Java Persistence Query Language (JPQL)

Clausulas : FROM Existen varias formas de simplificar una clase a la hora de realizar la consulta hql> FROM mx.model.Empleado hql> FROM Empleado Dando como resultado una colección de objetos de tipo Empleado SELECT la clausula SELECT selecciona cual(es) objeto (s)y cual (es) propiedad(es) se retornara en el resultado del query. hql> SELECT v.marca FROM Vehiculo as v hql> SELECT v.marca FROM Vehiculo v WHERE v.marca like ‘toy%’ hql> SELECT user.persona.nombre FROM Usuario user hql> SELECT user.username,p.nombre FROM Usuario user,Persona p La anterior consulta nos retorna Object[ ] WHERE Ayuda a filtrar la lista de instancias retornadas. hql> FROM Usuario user WHERE user.username = ‘rcuello’ hql> FROM Usuario user WHERE user.persona.cedula= hql> FROM Usuario user WHERE username.username IS NOT NULL ORDER BY La lista retornada por una consulta puede ser ordenada por cualquier propiedad de un objeto. hql> FROM Empleado emp ORDER BY emp.nombre asc 39

Practica JPA Curso de Java y Aplicaciones Web Crear una aplicación java con la siguiente estructura: Persona Id Nombre Apellido Cedula fechaNacimiento

Practica JPA Curso de Java y Aplicaciones Web Entidad Persona

Practica JPA Curso de Java y Aplicaciones Web Persistence

Practica JPA Curso de Java y Aplicaciones Web Tabla en Postgres Persona Id Nombre Apellido Cedula fechaNacimiento

Practica JPA Curso de Java y Aplicaciones Web Tabla en Postgres

Practica JPA Curso de Java y Aplicaciones Web Clase de prueba.

Practica JPA Curso de Java y Aplicaciones Web Agregar una o más fichas de contacto a cada persona. FichaContacto Id Telefono Calle Persona Id Nombre Apellido Cedula fechaNacimiento 1 n

Practica JPA Curso de Java y Aplicaciones Web Tabla ficha de Cantacto

Practica JPA Curso de Java y Aplicaciones Web Clase nueva FichaContacto

Practica JPA Curso de Java y Aplicaciones Web Modificar clase Persona

Practica JPA Curso de Java y Aplicaciones Web Agregar la nueva entidad a Persistence

Practica JPA Curso de Java y Aplicaciones Web Clase de prueba Creamos la persona. Creamos la ficha 1 para Persona. Creamos la ficha 2 para Persona.

Práctica 2  Mapear la clase curso y profesor como entidades.  Crear tablas en el Postgres para almacenar los valores.  Agregar un nuevo menú a GestionAcademicaWeb3 de “Guardar” para persistir los valores en BD. Curso de Java y Aplicaciones Web

Curso de Java y Aplicaciones Web. Ing. Esteban Ramírez