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

SQL Firebird Discussion :

Création d'une vue à l'éxécution


Sujet :

SQL Firebird

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 28
    Par défaut Création d'une vue à l'éxécution
    Bonjour à tous ,
    Je travaille avec Firebird 2.04 sous C++Builder XE Pro
    Voci ma problèmatique : j'ai une table impoortante > 1 millions d'enregistrements et à un moment donné mon utilisateur a besoin d'effectuer des modifications sur une fraction de cette table (<<1% de la table ) ;J'envisage donc de travailler sur une vue qui une fois créée permettra je l'espère une amélioration du traitement : Je souhaite donc créer ma vue en fonction d'un (Code) Mon souci est que je n'arrive pas à passer mon paramètre à la requete chargée d'effectuer la création de ma vue comme si dans une requete SQL "CREATE" on ne pouvait passer de paramètres ; en revanche si je passe ces parametres en "figé" ma vue se crée ....
    Voci mon code
    Code c++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    MaRequete->Active=false;
    MaRequete->SQL->Clear();
    marequete->SQL->Add("Create VIEW (code,champ1,champ2) as select code,champ1,champ2) from matable
    where code = :code ");
    MaRequete->ParamBynam("code")->Asinteger=805r;
    MaRequete->ExecSQL();
    j obtiens l'erreur
    ERREUR SQL generale invalid request BLR at offset 34 !!!!!!

    !! maintenant si j'utilise le code suivant ma vue se crée
    Code c++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    marequete->SQL->Add("Create VIEW (code,champ1,champ2) as select code,champ1,champ2) from matable
    where code = 805");

    Je ne suis pas certain que ce soit un problème SQL mais bon J'ai lu quelque part que Philippe makowski conseillait de passer par une procédure stockée : le souci est que je ne retrouve pas ce post et surtout aimerais comprendre pourquoi ma requete ne fonctionne pas .
    merci d'avance pour les réponses éventuelles

  2. #2
    Membre Expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 052
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 052
    Par défaut
    Bonjour,

    Non ce n'est pas possible de créer des vues "paramétrées".

    Et donc il vous faudra travailler avec directement votre select oubien passer par une procédure stoquée oubien encore mettre votre paramètre dans une table temporaire (mais là il faut Fb>=2.1).

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 28
    Par défaut
    Parfait Barbibulle
    Merci pour cette réponse express dont je redoutais la teneur ....

  4. #4
    Membre Expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Par défaut
    à l'évidence ici il faut travailler directement avec le select
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select code,champ1,champ2) from matable
    where code = :code
    je ne comprend pas où peut il y avoir problème ?

  5. #5
    Membre très actif Avatar de TryExceptEnd
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2006
    Messages : 501
    Par défaut
    Citation Envoyé par Didier44 Voir le message
    J'envisage donc de travailler sur une vue qui une fois créée permettra je l'espère une amélioration du traitement : Je souhaite donc créer ma vue en fonction d'un (Code) Mon souci est que je n'arrive pas à passer mon paramètre à la requete chargée d'effectuer la création de ma vue comme si dans une requete SQL "CREATE" on ne pouvait passer de paramètres ; en revanche si je passe ces parametres en "figé" ma vue se crée ....
    Ne me dis pas que tu veux créer une vue a chaque changement de paramètres !?
    C'est très intelligent comme méthode, au lieu d'utiliser une simple requête select filtrée avec un paramètre tu nous pond un truc que j'ai jamais vu déjà.

  6. #6
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 576
    Billets dans le blog
    65
    Par défaut
    Citation Envoyé par makowski Voir le message
    je ne comprend pas où peut il y avoir problème ?
    moi je ne comprend pas le besoin de passer par une vue !?

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. création d'une vue ...help
    Par menoce dans le forum Langage SQL
    Réponses: 3
    Dernier message: 06/07/2005, 21h30
  2. Réponses: 26
    Dernier message: 27/04/2005, 11h29
  3. Création d'une vue
    Par Xris dans le forum Langage SQL
    Réponses: 6
    Dernier message: 29/01/2005, 16h30
  4. Réponses: 7
    Dernier message: 12/07/2004, 22h30
  5. [Plugin] Création d'une vue dynamiquement
    Par The Bonze dans le forum Eclipse Platform
    Réponses: 2
    Dernier message: 15/06/2004, 13h23

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