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

QlikView Discussion :

Variables string dans script


Sujet :

QlikView

  1. #1
    Membre du Club
    Inscrit en
    Avril 2010
    Messages
    124
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 124
    Points : 60
    Points
    60
    Par défaut Variables string dans script
    Bonjour,

    Pour mon application, j'extraie les données de 5 bases concernant 5 lieux géographique différents. Ces bases ont exactement le même modèle de données (mêmes tables, mêmes nom de champs etc...)

    Je veux regrouper les informations au sein d'une même table. Le problème est que j'ai donc un Id_client = 1 dans les 3 bases de données.

    Ma techniques est donc de créer un champ "ville" quand j'importe mes données et à concaténer un indicateur de la ville devant chaque champs. Pour l'illustration, voici un exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    LOAD 
     
    'Paris' as Ville,
    'P'&id as id_client
     
    FROM ....

    Cela me permet ensuite de concaténer tranquillement les tables des différentes villes. Le problème est que le nombre de villes va augmenter donc j'aimerai éviter de devoir recopier à la main le 'P' devant chaque champs (rébarbatif + risque d'erreur).

    Je voudrais savoir s'il était possible de faire quelque chose du genre :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    LET vVille='P';
     
    LOAD
    $(vVille) as ville,
    $(vVille) & id;
     
    SQL SELECT * FROM TableParis;
    Le problème est qu'utilisé dans le load, le variable ne retient pas compte des cotes et donc ça plante...

    Avez-vous une idée ?

    Ou peut-etre une autre tactique pour éviter de réécrire à la main le 'P' pour chaque champs et pouor chaque ville.

    Merci pour votre aide

  2. #2
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    940
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 940
    Points : 1 409
    Points
    1 409
    Par défaut
    Bonjour, il suffit d'utiliser vVille ou '$(vVille)' :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    LET vVille='P';
    LOAD '$(vVille)' AS ville, '$(vVille)' & id as xid;
    SQL SELECT * FROM TableParis;
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    LET vVille='P';
    LOAD vVille AS ville, vVille & id as xid;
    SQL SELECT * FROM TableParis;

  3. #3
    Modérateur

    Inscrit en
    Octobre 2006
    Messages
    1 649
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 649
    Points : 2 529
    Points
    2 529
    Billets dans le blog
    6
    Par défaut
    Citation Envoyé par lozeba Voir le message
    Le problème est qu'utilisé dans le load, le variable ne retient pas compte des cotes et donc ça plante...

    Avez-vous une idée ?
    Oui : mettre des cotes

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    LET vVille='P';
    LOAD
    '$(vVille)' as ville,
    '$(vVille)' & id AS id;
    SQL SELECT * FROM TableParis;

  4. #4
    Membre du Club
    Inscrit en
    Avril 2010
    Messages
    124
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 124
    Points : 60
    Points
    60
    Par défaut
    Merci phunkyBob !

  5. #5
    Modérateur

    Inscrit en
    Octobre 2006
    Messages
    1 649
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 649
    Points : 2 529
    Points
    2 529
    Billets dans le blog
    6
    Par défaut
    Si vos tables ont vraiment la même structure, vous pouvez même faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    FOR EACH _ville in 'Paris', 'Lyon', 'Marseille'
    	LOAD
    	'$(_ville)' AS ville,
    	'$(_ville)|' & id AS id;
    	SQL SELECT * FROM Table$(_ville);
    NEXT

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 16/07/2008, 10h41
  2. Réponses: 3
    Dernier message: 05/02/2008, 12h03
  3. [TP] Copier une variable string dans le presse-papier
    Par astyan dans le forum Turbo Pascal
    Réponses: 7
    Dernier message: 04/08/2006, 22h47
  4. [VBA-E]Variable String dans un .formula
    Par marsupoilu dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 25/07/2006, 11h42
  5. [PHP/JavaScript] Variable php dans script Java
    Par Flushovsky dans le forum Langage
    Réponses: 2
    Dernier message: 27/06/2006, 19h51

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