Você está aqui: JPA - Java Persistence Architecture API - Arquitetura de Persistência Java ::: Dicas & Truques ::: Relacionamentos e Mapeamento de Entidades

Aprenda a usar o mapeamento Many-to-One (muitos para um) em suas aplicações JPA

Quantidade de visualizações: 3517 vezes
O mapeamento Many-to-One (muitos para um) ocorre quando temos várias entidades se relacionando com uma outra (e única) entidade. Como exemplo podemos citar as entidades Produto e Categoria. Cada produto pertence a apenas uma categoria e uma categoria pode possuir 0 ou mais produtos. No caso do mapeamento muitos-para-um nós estamos olhando a partir da entidade Produto. Se olhássemos a partir da entidade Categoria, o relacionamento seria um-para-muitos.

Como outro exemplo de mapeamento Many-to-One, considere as entidades Pedido e Cliente. Cada pedido pertence a apenas um cliente e um cliente pode possuir 0 ou vários pedidos.

Para começarmos, vamos criar duas tabelas no MySQL: produtos e categorias. Veja o comando SQL DDL CREATE TABLE para a tabela categorias:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


Veja que esta tabela possui apenas dois campos. O campo id é do int, auto-incremento e marcado como chave primária. O campo nome é do tipo varchar. Use o comando abaixo para inserir um registro nesta tabela:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


Se desejar, insira mais alguns registros na tabela categorias. Veja agora o comando SQL DDL CREATE TABLE para a tabela produtos:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


A tabela produtos possui os campos id (do tipo int, auto-incremento e chave primária), descrição (do tipo varchar), id_categoria (do tipo int e usado como chave estrangeira referenciando o campo id da tabela categorias) e preco (do tipo double).

Tendo criado as tabelas, passemos agora para a criação das entidades Produto e Categoria. Veja o código para a entidade Categoria:

Código para Categoria.java:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


Esta entidade não apresenta nada de novo, uma vez que o mapeamento será feito do lado "muitos", ou seja, na entidade Produto. Veja seu código agora:

Código para Produto.java:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


O primeiro ponto a observar é que a entidade Produto mantém uma referência a um objeto da classe Categoria. Há ainda o uso da anotação @ManyToOne para indicar o mapeamento (vários produtos para uma categoria) e @JoinColumn para indicar o campo da tabela produtos que foi usado como chave estrangeira para estabelecer a relação com a tabela categorias.

Vamos agora ao arquivo persistence.xml para que você veja como estas duas entidades são declaradas:

Código para persistence.xml:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


E, finalmente, a classe principal da aplicação:

Código para EstudosJPA.java:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


Ao executarmos este código, o EclipseLink vai disparar as seguintes instruções SQL:

Este trecho de código ou resolução de exercício faz parte do Super Pack 12.000 Dicas e Truques de Programação e 1.500 Exercícios Resolvidos em Java, Python, VisuAlg, Portugol, Delphi, C#, C, C++, VB.NET, Golang, Pascal, Ruby, PHP, e várias outras linguagens.

Aprenda a programar resolvendo problemas do mundo real. Tudo em português, com comentários em português.

Quero Ser Apoiador(a)


Link para compartilhar na Internet ou com seus amigos:

Veja mais Dicas e truques de JPA - Java Persistence Architecture API - Arquitetura de Persistência Java

Dicas e truques de outras linguagens

E-Books em PDF

E-Book 350 Exercícios Resolvidos de Java - PDF com 500 páginas
Domine lógica de programação e a linguagem Java com o nosso E-Book 350 Exercícios Exercícios de Java, para você estudar onde e quando quiser.

Este e-book contém exercícios resolvidos abrangendo os tópicos: Java básico, matemática e estatística, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book
E-Book 650 Dicas, Truques e Exercícios Resolvidos de Python - PDF com 1.200 páginas
Domine lógica de programação e a linguagem Python com o nosso E-Book 650 Dicas, Truques e Exercícios Exercícios de Python, para você estudar onde e quando quiser.

Este e-book contém dicas, truques e exercícios resolvidos abrangendo os tópicos: Python básico, matemática e estatística, banco de dados, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book

Linguagens Mais Populares

1º lugar: Java
2º lugar: Python
3º lugar: C#
4º lugar: PHP
5º lugar: C
6º lugar: Delphi
7º lugar: JavaScript
8º lugar: C++
9º lugar: VB.NET
10º lugar: Ruby



© 2025 Arquivo de Códigos - Todos os direitos reservados
Neste momento há 31 usuários muito felizes estudando em nosso site.