[firebase-br] RES: RES: RES: campos duplicados
Reijanio Nunes Ribeiro
rnribeiro em gmail.com
Dom Dez 19 10:20:08 -03 2010
modifiquei eles para poder agregar mais campos porem da a mensagem da
exception pra todos os arquivos inseridos
e não salva
CREATE OR ALTER PROCEDURE VERIF_PROD_EST (
p_cod integer,
p_codprod varchar(18),
p_local char(3),
p_cod_emp integer,
p_dt date)
as
begin
for select codprod, cod_local from estoque
into :p_codprod, :p_local do
begin
if(Exists(select * from estoque WHERE codprod =:p_codprod and cod_local
=:p_local))then
begin
exception produtoexistente;
end
else
begin
insert into estoque(codigo,codprod, cod_local, cod_emp, dt_entrada)
values
(
:p_cod,
:p_codprod ,
:p_local,
:p_cod_emp,
:p_dt
);
end
end
end^
Em 19 de dezembro de 2010 07:59, Reijanio Nunes Ribeiro <rnribeiro em gmail.com
> escreveu:
> acho que consegui quero só o aval dos amigos pois não sei se vai dar certo
> mais vejam como fiz
>
> CREATE OR ALTER PROCEDURE VERIF_PROD (
> p_idprod varchar(18),
> p_idtab integer)
> as
> begin
> for select idprod, idtab from estoque
> into :p_idprod, :p_idtab do
> begin
> if(Exists(select * from preco_tabela WHERE idprod =:p_idprod and idtab
> =:p_idtab))then
> begin
> exception produtoexistente;
> end
> else
> begin
> insert into preco_tabela(idprod, idtab)
> values
> (
> :p_idprod ,
> :p_idtab
> );
> end
> end
>
>
> Em 19 de dezembro de 2010 07:39, Reijanio Nunes Ribeiro <
> rnribeiro em gmail.com> escreveu:
>
> seguinte pessoal a sintaxe do sql seria assim
>> select * from preco_tabela where idprod = :pcod and idtab = :ptab
>> assim seria perfeito agora como como fazer uma stored procedure que
>> impeça a inserção destes items caso ja existam na tabela
>>
>> Em 19 de dezembro de 2010 07:25, Reijanio Nunes Ribeiro <
>> rnribeiro em gmail.com> escreveu:
>>
>> seria um teressante um select que fizesse o laço na tabela e verificasse a
>>> existencia dos dois campos alguem tem alguma ideia de como fazer isso achar
>>> dois campos em linhas identicos e tentar localizar e impedir de inserir esse
>>> select é que to apanhnado pois um campo so é facil mais dois assim não estou
>>> dando conta
>>>
>>> Em 19 de dezembro de 2010 07:20, Reijanio Nunes Ribeiro <
>>> rnribeiro em gmail.com> escreveu:
>>>
>>> robson a questão é que vou te exemplificar
>>>> tenho
>>>> idprod idtab
>>>> 001 1
>>>> 001 2
>>>>
>>>> se colocar um indice nele vai dar erro por que ele so vai aceitar um
>>>> unico idprod e idtab, vou tentar gerar uma stored procedure que leia od dois
>>>> campos e gere uma exceção, ou uma sintaxe que faça isso, creio que sejam
>>>> minhas opções ja que não posso amarra-las por indices unicos pois esta
>>>> tabela podem conter varios produtos iguais e tabelas diferentes
>>>>
>>>> Em 18 de dezembro de 2010 17:10, Robson Catunda <
>>>> robson.catunda em gmail.com> escreveu:
>>>>
>>>> Reijanio,
>>>>>
>>>>> volto a insistir.. crie um índice único.
>>>>>
>>>>> Delete os duplicados antes de executar o comando abaixo, pois se já
>>>>> existirem duplicações o indice não será criado.
>>>>>
>>>>> *ALTER TABLE* *NOME_DA_TABELA ADD CONSTRAINT* *NOME_DO_INDICE* *UNIQUE
>>>>> (IDTAB, IDPROD);
>>>>> *
>>>>> Esse indice amarra codigo de tabela e codigo de produto exatamente como
>>>>> vc
>>>>> quer. Vai poder ter o mesmo produto em varios codigos de tabelas
>>>>> distintas,
>>>>> mas não poderá ter o mesmo codigo de produto mais de uma vez no mesmo
>>>>> código
>>>>> de tabela.
>>>>> ______________________________________________
>>>>> FireBase-BR (www.firebase.com.br) - Hospedado em www.locador.com.br
>>>>> Para saber como gerenciar/excluir seu cadastro na lista, use:
>>>>> http://www.firebase.com.br/fb/artigo.php?id=1107
>>>>> Para consultar mensagens antigas: http://firebase.com.br/pesquisa
>>>>>
>>>>
>>>>
>>>
>>
>
Mais detalhes sobre a lista de discussão lista