Forum Pplware

Versão Completa: Verificar se existem dados da BD
Está de momento a ver uma versão reduzida do nosso conteúdo. Ver versão completa com o formato adequado.
Boa tarde ,

Eu estou a fazer um insert de dados na minha BD e gostava de saber como verifico se os dados ja existem que é para não adicionar dados duplicados na BD

Eu pensei assim mas nao sei como verificar dentro do if se os dados ja existem na bd :

Código:
if ( )
{
      messagebox.show("Campo ja adicionado ");
}
else
{
//Insert
            SqlCeCommand cmd = new SqlCeCommand(" INSERT into vendas (id,nome,preco) VALUES ('" + resultado.ToString() + "','" + listBox1.SelectedItem + "','" + label2.Text + "' )", liga);
            cmd.ExecuteNonQuery();
}


Desde ja o meu obrigado pela ajuda
Que tal fazeres um select primeiro a bd e dentro do if verificas se tem ou nao registos??

Cumps,
deverias criar na DB a coinstraint para não permitir registos duplicados.

Como se faz?
Crias um indíce com os campos todos que precisas garantir a unicidade e dizes que esse indice é único.
(07-06-2011 19:13)JPedrosa Escreveu: [ -> ]deverias criar na DB a coinstraint para não permitir registos duplicados.

Como se faz?
Crias um indíce com os campos todos que precisas garantir a unicidade e dizes que esse indice é único.

Exactamente deves sempre garantir de ambos os lados (BD e Aplicação) a integridade dos dados.

Cumps,
Obrigado a todos pelas respostas Smile esta resolvido
(07-06-2011 22:32)marfonte Escreveu: [ -> ]
(07-06-2011 19:13)JPedrosa Escreveu: [ -> ]deverias criar na DB a coinstraint para não permitir registos duplicados.

Como se faz?
Crias um indíce com os campos todos que precisas garantir a unicidade e dizes que esse indice é único.

Exactamente deves sempre garantir de ambos os lados (BD e Aplicação) a integridade dos dados.

Cumps,

Viva,
do lado aplicação o mais simples, é em cada objecto que tens, implementares o método "exists" que tipicamente recebe um ID e devolve um bool
E depois, antes de mandares criar algo na DB, chamas o "exists", e tens o código de inserção dentro de um if onde a condição para a execução é o "exists" ser true.

Assim, desta forma, só tentas fazer o insert se for efectivamente necessário.

Ainda assim, deves tratar a SQL Exception de retorno, porque pode algo correr mal, para além de duplicados ..
URL's de Referência