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 :

Problèmes avec les vues et les sequences postgresql


Sujet :

Requêtes PostgreSQL

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    465
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 465
    Par défaut Problèmes avec les vues et les sequences postgresql
    Bonjour,
    je travaille sur une base de données postgresql. J'ai créé une vue qui s'appelle ma_vue qui utilise un nextval sur une sequence pour créer un identifiant unique. Jusqu'à ici tout va bien.
    Lorsque je fais un "select from ma_vue", j'obtiens un résultat correct et la vue ne change pas. Alors que lorsque je fais un "select from ma_vue where condition", la vue elle même change.
    Pourriez vous SVP m'indiquer une manière pour que ma vue ne change pas en faisant un select from ma_vue where condition. merci

  2. #2
    Membre éprouvé Avatar de kain_tn
    Homme Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 864
    Par défaut
    Bonjour,

    Pourrais-tu poster tes requêtes stp? Mieux, pourrais-tu également poster le résultat de tes requêtes en les précédant d'un 'explain analyse'?

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    465
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 465
    Par défaut
    Citation Envoyé par kain_tn Voir le message
    Bonjour,

    Pourrais-tu poster tes requêtes stp? Mieux, pourrais-tu également poster le résultat de tes requêtes en les précédant d'un 'explain analyse'?
    On fait, j'ai créé une séquence seq comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE SEQUENCE seq MINVALUE 1 MAXVALUE 1000 CYCLE
    sachant que j'ai 1000 ligne à traiter.
    Puis j'ai crée ma vue:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE OR REPLACE VIEW ma_vue (id, layer) AS SELECT nextval('seq'), layer FROM ma_table
    .
    si je fais un select * FROM ma_vue j'obtiens toutes lignes de la vue.
    Et si je fais select * FRom ma_vue WHERE condition, le champs id de la vue de commence plus par 1.

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Par défaut
    Le problème n'est pas dans l'application d'une condition WHERE à la vue. Pour preuve, tu peux lancer deux fois de suite select * from vue, et tu devrais voir que déjà entre les deux exécutions, les résultats ne sont pas les mêmes.

    Le problème est que l'utilisation d'une séquence dans une vue ne convient pas pour créer l'équivalent d'une clef unique, puisque la valeur change à chaque fois qu'on y accède.

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    465
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 465
    Par défaut
    j'ai opté pour une solution qui consiste à remplacer le nextval de la séquence par la valeur d'oid de la ligne correspondante dans les tables origines de la vue et comme ça j'obtiens une clé primaire sans utiliser une séquence.

Discussions similaires

  1. Réponses: 2
    Dernier message: 02/08/2006, 16h46
  2. [Tableaux] Problème avec un array et les pseudo frame
    Par azerty53 dans le forum Langage
    Réponses: 6
    Dernier message: 10/05/2006, 14h57
  3. Problème avec l'unicode et les exceptions
    Par Rafy dans le forum C++
    Réponses: 5
    Dernier message: 07/02/2006, 00h52
  4. problème avec strtok pour récupérer les vides
    Par manikou dans le forum MFC
    Réponses: 4
    Dernier message: 02/06/2005, 20h08

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