IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Requêtes PostgreSQL Discussion :

Récupérer un RAISE EXCEPTION


Sujet :

Requêtes PostgreSQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 7
    Points : 6
    Points
    6
    Par défaut Récupérer un RAISE EXCEPTION
    Bonjour,
    voici mon trigger qui vérifie avant l'insertion dans ma table Client que le login n'est pas déjà utilisé par un client existant :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    CREATE FUNCTION veriflogin() RETURNS trigger AS $triginsert$
     
    declare 
        ligne record;  
        test integer;
     
    begin
     
    SELECT * INTO ligne FROM CLIENT WHERE login_cli = NEW.login_cli;
          GET DIAGNOSTICS test = ROW_COUNT;
          IF (test != 0) THEN 
            RAISE EXCEPTION 'Login déjà utilisé';
          END IF;
     
    return NEW;
    END;
    $triginsert$ LANGUAGE plpgsql;
     
    CREATE TRIGGER triginsert BEFORE INSERT OR UPDATE ON CLIENT
    FOR EACH ROW EXECUTE PROCEDURE veriflogin();
    Mon problème est que ne sais pas comment récupérer le contenu du RAISE EXCEPTION lorsque que je fais (dans mon script php) un insert avec un login existant...

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,

    Pour la partie php, demandez sur le forum approprié.

    Par contre pourquoi faire un trigger qui gère ceci quand vous pourriez utiliser un index unique qui :
    - vous garantira l'excluvité du nom, pas comme votre trigger
    - utilisera moins de ressource lors des update / insert

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    create unique index idx_client_login on client (login_cli);

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 7
    Points : 6
    Points
    6
    Par défaut
    Oui effectivement (mon champs etait UNIQUE auparavant ) mais je voulais essayer de faire un trigger...
    Ce n'était peut etre pas le bon sujet d'exercice
    En tout cas Merci de ta reponse

Discussions similaires

  1. conseil raise exception
    Par looping dans le forum Langage
    Réponses: 6
    Dernier message: 11/02/2014, 11h10
  2. [PDO] Catcher un raise exception
    Par spike75 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 28/04/2012, 21h46
  3. Récupérer type d'exception SoapFault
    Par romcube dans le forum Services Web
    Réponses: 0
    Dernier message: 15/03/2009, 23h49
  4. pb :RAISE EXCEPTION
    Par Nimothenicefish dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 12/06/2008, 16h59
  5. Raise Exception avec mysql ?
    Par pop_up dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 27/08/2007, 08h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo