SQL - Problema ids de tabelas relacionadas

5 respostas
springsql
alan121

Bom dia

Estou com uma dúvida que não acho pesquisando. Coloquei no stack overflow, só q só negativaram a pergunta.

tenho um db postgress, q foi gerado com entidades spring boot no Java, daí, tem 2 tabelas relacionadas e quando o banco vai gerar o id para os registros em cada uma, não gera de maneira independente.

Tipo, para a entidadeA gera id = 1, 2, 3…, aí vou cadastrar um registro da entidadeB e gera id = 4, 5, 6, 7, cadastro mais 2 da A e vem id = 8, 9… entendeu? queria deixar o id indenpendente entre as tabelas

5 Respostas

Jonathan_Medeiros

Isso acontece porquê provavelmente você está utilizando a estratégia de sequence para gerar os IDs, e a sequence utilizada provavelmente é única para todas as tabelas!

Como sugestão, já que você está utilizando PostgreSQL, defina a coluna ID das suas tabelas com o tipo SERIAL que basicamente é um tipo de auto incremento, depois ajusta os IDs nas suas entidades alterando de sequence para identity.

Lucas_Camara

@alan121 complementando a resposta do @Jonathan_Medeiros, vc pode ter uma sequence para cada tabela. Mas é importante a gente saber como vc está fazendo para gerar esses IDs.

alan121

obrigado por responder

como coloco esse SERIAL? É no proprio Java ou no banco?

E no atributo id estou fazendo tipo assim:

@Table(name = “tabelaA”)
public Class EntidadeA {

@Id

@GeneratedValue(strategy =GenerationType.AUTO)

private Integer idA;

daí, mudaria o AUTO para IDENTITY, certo?

Jonathan_Medeiros

Isso mesmo, coluna do tipo SERIAL no banco e IDENTITY na entidade.

alan121

Fiz assim, vou ver o que vai dar. Valeu, cara.

Criado 5 de maio de 2022
Ultima resposta 7 de jun. de 2022
Respostas 5
Participantes 3