AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / dba / Perguntas / 317133
Accepted
Jeroen Vermunt
Jeroen Vermunt
Asked: 2022-09-21 02:36:34 +0800 CST2022-09-21 02:36:34 +0800 CST 2022-09-21 02:36:34 +0800 CST

Como lidar com clientes duplicados?

  • 772

Isso provavelmente é de conhecimento comum para DBAs, mas no meu banco de dados estou lutando com um simples cadastro de clientes.

Os clientes podem se inscrever usando um formulário (usamos typeform ), o que significa que criamos registros de clientes sem um formulário de registro real.

O que fazer se os clientes se registrarem duas vezes? Ou quando clientes diferentes (talvez parceiros) se registram com o mesmo endereço de e-mail?

É sensato impor UNIQUErestrições, por exemplo, no endereço de e-mail, para evitar registros duplicados? Parece a melhor coisa a fazer, mas posso imaginar que isso causará problemas no futuro.

O principal motivo seria o envio de um formulário com um endereço de e-mail já no banco de dados. Se eu obtiver uma duplicata, provavelmente quero substituir os dados do formulário antigo pela resposta mais recente. No entanto, aqui corro o risco de envios "falsos" que substituem dados antigos por dados falsos. Se eu não substituir o registro antigo, posso perder as informações mais recentes.

Talvez eu esteja pensando demais na questão, mas acho difícil fazer uma escolha decisiva.

Se eu não aplicar a restrição de e-mail, há uma chance de ocorrerem registros duplicados quando o mesmo cliente preencher o formulário duas vezes (isso acontece ocasionalmente). Isso é super chato, pois agora a equipe tem que lidar com dois registros e não sabe qual é o correto.

Existe uma boa maneira de lidar com esse problema? Ou é melhor simplesmente escolher um e lidar com as consequências?

database-design unique-constraint
  • 1 1 respostas
  • 42 Views

1 respostas

  • Voted
  1. Best Answer
    Erwin Smout
    2022-09-21T05:36:24+08:002022-09-21T05:36:24+08:00

    A identificação via endereço de e-mail normalmente também envolve autenticação por endereço de e-mail (por exemplo, enviar um e-mail para o endereço solicitado e registrar-se somente após a resposta a esse e-mail). Depois desse ponto (quando o registro for feito), o "design cauteloso" exigirá que você não permita a substituição do registro existente com muita facilidade ou leveza, significando essencialmente: apenas permitido pelo mesmo usuário que se autenticou corretamente mais uma vez . Ou trabalhando com e-mails de confirmação onde qualquer alteração só é efetivada após o recebimento da confirmação.

    • 4

relate perguntas

  • Os índices filtrados podem ajudar a melhorar as consultas baseadas em uma hora inserida ou isso deve ser evitado?

  • Qual é a diferença entre os tipos de dados MySQL VARCHAR e TEXT?

  • É melhor armazenar os valores calculados ou recalculá-los a pedido? [duplicado]

  • Armazenar vs calcular valores agregados

  • Quais são algumas maneiras de implementar um relacionamento muitos-para-muitos em um data warehouse?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    conectar ao servidor PostgreSQL: FATAL: nenhuma entrada pg_hba.conf para o host

    • 12 respostas
  • Marko Smith

    Como fazer a saída do sqlplus aparecer em uma linha?

    • 3 respostas
  • Marko Smith

    Selecione qual tem data máxima ou data mais recente

    • 3 respostas
  • Marko Smith

    Como faço para listar todos os esquemas no PostgreSQL?

    • 4 respostas
  • Marko Smith

    Listar todas as colunas de uma tabela especificada

    • 5 respostas
  • Marko Smith

    Como usar o sqlplus para se conectar a um banco de dados Oracle localizado em outro host sem modificar meu próprio tnsnames.ora

    • 4 respostas
  • Marko Smith

    Como você mysqldump tabela (s) específica (s)?

    • 4 respostas
  • Marko Smith

    Listar os privilégios do banco de dados usando o psql

    • 10 respostas
  • Marko Smith

    Como inserir valores em uma tabela de uma consulta de seleção no PostgreSQL?

    • 4 respostas
  • Marko Smith

    Como faço para listar todos os bancos de dados e tabelas usando o psql?

    • 7 respostas
  • Martin Hope
    Jin conectar ao servidor PostgreSQL: FATAL: nenhuma entrada pg_hba.conf para o host 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane Como faço para listar todos os esquemas no PostgreSQL? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh Por que o log de transações continua crescendo ou fica sem espaço? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland Listar todas as colunas de uma tabela especificada 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney O MySQL pode realizar consultas razoavelmente em bilhões de linhas? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx Como posso monitorar o andamento de uma importação de um arquivo .sql grande? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison Como você mysqldump tabela (s) específica (s)? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas Como posso cronometrar consultas SQL usando psql? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas Como inserir valores em uma tabela de uma consulta de seleção no PostgreSQL? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas Como faço para listar todos os bancos de dados e tabelas usando o psql? 2011-02-18 00:45:49 +0800 CST

Hot tag

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve