TrabalhosGratuitos.com - Trabalhos, Monografias, Artigos, Exames, Resumos de livros, Dissertações
Pesquisar

Persistência de Dados JDBC e JPA

Por:   •  25/10/2019  •  Artigo  •  10.380 Palavras (42 Páginas)  •  131 Visualizações

Página 1 de 42

Persistência JDBC e JPA

Giovane Belizário de Souza

Índice

  1. Introdução ................................................................................................1
  2. Aplicação exemplo ...................................................................................2
  3. JDBC .........................................................................................................3
  1. Introdução ..........................................................................................3
  2. Transação ...........................................................................................3
  3. Cache .................................................................................................7
  4. Concorrência ....................................................................................10
  1. JPA ..........................................................................................................13
  1. Introdução ........................................................................................13
  2. Transação .........................................................................................16
  3. Cache ...............................................................................................19
  4. Concorrência ....................................................................................21
  1. Conclusão ...............................................................................................22
  2. Bibliografia .............................................................................................23

Introdução

        Neste artigo será apresentado de maneira breve e direta a utilização das tecnologias JDBC e JPA para persistência de dados na plataforma Java, o tópicos debatidos são Transação, Cache e Concorrência.

Transação

        Uma operação ou um conjunto de operações que devem ser executadas como uma unidade, ou todas operações são executadas ou nenhuma delas.

Cache

        Uma área de armazenamento onde os dados(Objetos, referências e queries) frequentemente utilizados são guardados para um acesso mais rápido diminuindo a necessidade de acessar o banco de dados.

Concorrência

        A execução de duas ou mais transações referentes a mesma informação.


Aplicação exemplo

        Aplicação de pedidos de um restaurante onde o atendente associa um pedido a uma mesa, insere itens no pedido conforme solicitado pelo cliente e inicia um pedido, onde ele pode alterar conforme o cliente solicita e ao final é fechado o pedido onde é inserida a data de fechamento do pedido e o pedido e seus itens são gravados atualizados.

Segue abaixo as classes utilizadas:

public class Produto {

        

        private int codigo;

        private String descricao;

        private float valor;

        //getters e setters

}

public class Item {

        private int codigoPedido;

        private int codigo;

        private Produto produto;

        private int quantidade;

        private float valorTotal;

        //getters e setters

}

public class Pedido {

        

        private int codigo;

        private int versao;

        private String atendente;

        private int numeroMesa;

        private List listaItem;

        private Date dataFechamento;

        //getters e setters

}


JDBC

Introdução

O JDBC é uma API padrão e nativa do Java para acesso a bancos de dados independentes desde a versão 1.1 lançada em 1995. Com o JDBC é possível executar as três mais necessárias tarefas quando se trata de acesso a banco de dados: Estabelecer uma conexão com banco de dados, enviar instruções SQL e processar respostas, necessitando apenas de um driver de conexão com o banco de dados utilizado.

Transação

        Quando uma conexão com via JDBC é criada, por padrão esta configurada como autoCommit , isso quer dizer que cada instrução SQL será tratada como uma transação e será automaticamente commitada depois de executada na aplicação.

Pense no nosso exemplo de aplicação, quando o atendente inicia um pedido, tanto o pedido quanto seus itens devem ser inseridos para que haja consistência de informações no banco de dados. Caso cada instrução SQL seja tratada como uma transação e haja algum problema de conexão com o banco de dados durante a execução do método iniciarPedido(), no qual executa primeiro a inserção do objeto Pedido e depois da lista de objetos Item, podemos ter em nosso banco de dados um pedido inserido, porém com itens faltando ou mesmo sem itens associados.

...

Baixar como (para membros premium)  txt (41.4 Kb)   pdf (226 Kb)   docx (38.5 Kb)  
Continuar por mais 41 páginas »
Disponível apenas no TrabalhosGratuitos.com