[Postgresql] Procédure avec if ne fonctionne

Résolu/Fermé
rgdu86 Messages postés 275 Date d'inscription mercredi 23 mai 2007 Statut Membre Dernière intervention 7 juillet 2014 - 16 mars 2008 à 11:35
rgdu86 Messages postés 275 Date d'inscription mercredi 23 mai 2007 Statut Membre Dernière intervention 7 juillet 2014 - 16 mars 2008 à 13:10
Bonjour à tous,

J'ai une base de données sur postgresql sur windows et j'ai une procédure qui ne veut pas être créée.

Voici à quoi ressemble ma procédure :

CREATE FUNCTION majsoldebanque ()
RETURNS float
AS
'
declare

idCompte integer;

sens character;

montant money;

if(sens='c') then

update COMPTE set SoldeBanque_Compte=SoldeBanque_Compte+@montant

where Id_Compte=@idCompte

else

update COMPTE set SoldeBanque_Compte=SoleBanque_Compte-@montant

where Id_Compte=@idCompte

endif

end
'
LANGUAGE 'plpgsql';

et voici le message d'erreur qui m'est affiché :

ERROR: syntax error at OR near "c"
LINE 13: IF(sens='c') then
^

********** Erreur **********

ERROR: syntax error at OR near "c"
État SQL :42601
Caractère : 129

Cette fonction me permettrai de mettre à jour un solde de compte bancaire.

Comment faire pour résoudre cette erreur ?

C'est assez important, j'en ai besoin très rapidement.

Par avance, merci.

Bien cordialement.

rgdu86

2 réponses

Bonjour,

Je ne connais pas ce langage mais je vais te donner des pistes par rapport à des langages que je connais.

if(sens='c') then

La variable locale sens est definie character mais n'est pas initialisée (aucune valeur ne lui est affectée)..
Pareil pour idCompte.

La syntaxe du test if ne serait pas plutot if (sens=='c') then
Les lignes d'instructions ne devraient pas se terminer par le point-virgule ;

En esperant t'avoir dépanné un peu
A+.
0
rgdu86 Messages postés 275 Date d'inscription mercredi 23 mai 2007 Statut Membre Dernière intervention 7 juillet 2014 65
16 mars 2008 à 13:10
Après avoir bidouiller dans tout les sens, voici la bonne réponse :

CREATE OR REPLACE FUNCTION majsoldebanque(idcompte integer, sens bpchar, montant double precision)
RETURNS double precision AS

begin
if(sens=c)then
update COMPTE set SoldeBanque_Compte=SoldeBanque_Compte+montant
where Id_Compte=idCompte;
else
update COMPTE set SoldeBanque_Compte=SoldeBanque_Compte-montant
where Id_Compte=idCompte;
end if;
end;
LANGUAGE 'plpgsql' VOLATILE

Merci quand même amigo.

Bien cordialement.

rgdu86
0

Discussions similaires