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

Oracle Discussion :

SQLLDR - control file special


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Avril 2005
    Messages : 53
    Par défaut SQLLDR - control file special
    Bonjour,

    J'ai un peu de mal à concevoir mon fichier de controle :

    En entrée j'ai un fichier texte, les champs sont séparés par des ';'.

    J'ai besoin de le charger dans 2 champs de la table cible de la façon suivante :
    Champ1_cible = champ1_source + '_' + champ2_source
    Champ2_cible = toute la ligne source (incluant les 2 champs déjà traité au dessus)
    La taille des champs source n'est pas fixe.

    Est ce possible ? si oui, comment réalisé mon fichier de controle ?

    Pour l'instant j'ai fait ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    LOAD DATA
    INTO TABLE "TMP"
    APPEND
    TRAILING NULLCOLS (
    C_1 ?????? ,
    C_2 CHAR(4000) TERMINATED BY '\r'
    )

  2. #2
    Rédactrice

    Avatar de kalyparker
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Janvier 2007
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 327
    Par défaut
    Bonjour,

    ce genre de question à déjà été posté

    Il faut passer par une table temporaire pour faire ce genre de chose.

    Par contre ta requete ne risque pas de marcher si tu n'utilise pas FIELDS TERMINATED BY';'

    en gros tu devrais avoir quelques choses comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    LOAD DATA INFILE 'mon_fichier.txt'
    APPEND
    INTO TABLE "TMP"
    FIELDS TERMINATED BY';'
    (C_1,C_2)
    It isn't that they can't see the solution, it's that they can't see the problem.
    Mes Articles et Traductions (Microstrategy, Css et Javascript)
    Si vous souhaitez contribuer à la rubrique BI, contactez-moi ou tout autre membre de l'équipe BI par MP.

  3. #3
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    passer par une external table ce serait aussi bien

  4. #4
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 462
    Par défaut
    Citation Envoyé par kalyparker
    Il faut passer par une table temporaire pour faire ce genre de chose.
    Je pratique peu SQL*Loader, et je n'en maîtrise pas les subtilités, mais il me semble qu'on n'a pas besoin d'en passer par des tables temporaires pour si peu.
    En effet, même pour des champs avec séparateur, on peut utiliser le mot-clé POSITION(1) pour revenir à la première colonne de la ligne, ce qui permet de relire le premier champ.

  5. #5
    Rédactrice

    Avatar de kalyparker
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Janvier 2007
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 327
    Par défaut
    En effet, même pour des champs avec séparateur, on peut utiliser le mot-clé POSITION(1) pour revenir à la première colonne de la ligne, ce qui permet de relire le premier champ.
    Je sais pas, j'ai jamais testé.

    En fait c'était surtout pour la première partie de la condition que je disais qu'il fallait utiliser une table temporaire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Champ1_cible = champ1_source + '_' + champ2_source
    Car je crois qu'il n'est pas possible de faire cela d'une autre façon. (ce n'est que mon avis )
    It isn't that they can't see the solution, it's that they can't see the problem.
    Mes Articles et Traductions (Microstrategy, Css et Javascript)
    Si vous souhaitez contribuer à la rubrique BI, contactez-moi ou tout autre membre de l'équipe BI par MP.

  6. #6
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Citation Envoyé par Pomalaix
    En effet, même pour des champs avec séparateur, on peut utiliser le mot-clé POSITION(1) pour revenir à la première colonne de la ligne, ce qui permet de relire le premier champ.
    mais malheureusement il s'arrête au 1° séparateur en principe

Discussions similaires

  1. Réponses: 9
    Dernier message: 07/09/2006, 14h19
  2. ora-27040 erreur creation control file
    Par pascale86 dans le forum Oracle
    Réponses: 23
    Dernier message: 19/01/2006, 16h54
  3. ora-00205 - erreur fichier de control files
    Par pascale86 dans le forum Oracle
    Réponses: 15
    Dernier message: 17/01/2006, 09h28
  4. Un générateur de Control File pour SQL*Loader ?
    Par lex0072 dans le forum Oracle
    Réponses: 7
    Dernier message: 21/10/2005, 12h36
  5. Control files ORA-00214
    Par MAGNUM_HEAD dans le forum Oracle
    Réponses: 7
    Dernier message: 04/03/2005, 11h55

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