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 :

Problème avec EXECUTE STATEMENT


Sujet :

SQL Firebird

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de freud
    Homme Profil pro
    Développeur
    Inscrit en
    Mai 2002
    Messages
    1 271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 271
    Par défaut Problème avec EXECUTE STATEMENT
    Bonjour,

    Voilà, cela fait quelque jour que je galère en cherchant à construire en vain une requête en dynamique pour l'utiliser avec un EXECUTE STATEMENT dont voici le code :
    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
    21
    22
    23
     
    BEGIN
     VARSQL='SELECT T.ROWID, T.RUB_POSITION, T.TYPE_SAL, T.CODE_RUB,  R.DESIGNATION, T.USERNAME, T.MODIFIED, ';
    VARSQL=:VARSQL||'R.DESCRIPTION,R.CALCUL_ACTIVER';
     VARSQL=:VARSQL||' FROM PA_TB_TYPESAL_DET T INNER JOIN PA_TB_PROF R ON T.CODE_RUB=R. CODE_RUB;
     
     if (:type_salaire<>'' AND :activer<>'') then
       VARSQL=:VARSQL||' where T.TYPE_SAL = '''|| TYPE_SALAIRE ||''' AND   R.calcul_activer = '''|| ACTIVER;
     
     if (:type_salaire='' AND :activer<>'') then
       VARSQL=:VARSQL||' where R.calcul_activer = '''|| ACTIVER;
     
     if (:type_salaire<>'' AND :activer='') then
       VARSQL=:VARSQL||' where T.TYPE_SAL = '''|| TYPE_SALAIRE;
     
     VARSQL=:VARSQL||' ORDER BY '|| ORDER_BY ;
     
     FOR EXECUTE STATEMENT VARSQL
      into :rowid,:rub_position,:type_sal,:code_rub,:calcul_activer, :description,:username,:modified
      DO
      suspend;
     
    END
    Si je désactive les chaines se trouvant dans les tests des IF's en ne laissant que la chaine de l'ORDER BY ca marche bien.

    Si je met le même nombre de côtes que celle qui se trouve dans l'ORDER BY dans les chaines que j'ai désactiver ca ne marche pas .

    Problème de côtes mais je ne sais pas comment exactement.

    Merci pour votre aide

  2. #2
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 591
    Billets dans le blog
    65
    Par défaut
    bonsoir,

    effectivement plusieurs problèmes de quotes (du moins à mon avis et celui de la mise en page)

    ACTIVER et TYPE_SALAIRE Semblant être un CHAR ou VARCHAR , la chaine n'est pas terminée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     VARSQL=:VARSQL||' FROM PA_TB_TYPESAL_DET T INNER JOIN PA_TB_PROF R ON T.CODE_RUB=R. CODE_RUB';
     
    
    
     if (:type_salaire<>'' AND :activer<>'') then
       VARSQL=:VARSQL||' WHERE T.TYPE_SAL = '''|| TYPE_SALAIRE ||''' AND   R.calcul_activer = '''|| ACTIVER||'''';
     
     if (:type_salaire='' AND :activer<>'') then
       VARSQL=:VARSQL||' WHERE R.calcul_activer = '''|| ACTIVER||'''';
     
     if (:type_salaire<>'' AND :activer='') then
       VARSQL=:VARSQL||' WHERE T.TYPE_SAL = '''|| TYPE_SALAIRE||'''';
    Pour ORDER_BY c'est différent , je n'en voit même pas la valeur

  3. #3
    Membre éprouvé Avatar de freud
    Homme Profil pro
    Développeur
    Inscrit en
    Mai 2002
    Messages
    1 271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 271
    Par défaut
    Super !
    ca marche trés bien !!! merci beaucoup SergioMaster
    ACTIVER et TYPE_SALAIRE sont effectivement de type CHAR
    Egalement pour l'ORDER BY qui est de type VARCHAR auquel j'affecte les noms de champs ou sinon la position du champ dans le select 1,2.3 etc....
    Désolé pour la mise en page, ca ne donne pas une bonne lecture du code je n'ai pas su d'oû ca vient probablement dû au manque de côtes dans texte poster ?

    En tout cas merci.

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

Discussions similaires

  1. Problème avec execute immediate
    Par jojo280 dans le forum SQL
    Réponses: 7
    Dernier message: 05/07/2008, 18h25
  2. problème avec executable
    Par ulysse031 dans le forum Débuter avec Java
    Réponses: 4
    Dernier message: 22/04/2008, 09h08
  3. [Transact-SQL] Problème avec "execute" dans un "if"
    Par dj_lil dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 18/12/2007, 15h56
  4. problème avec les statements
    Par samil dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 28/08/2007, 08h21
  5. Problème avec "Executer" - Problème de thèmes
    Par NeraOne dans le forum Windows XP
    Réponses: 4
    Dernier message: 10/07/2007, 10h08

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