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

PL/SQL Oracle Discussion :

Traitement à la chaine


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 40
    Par défaut Traitement à la chaine
    Bonjour

    je sollicite votre aide sur une petite bricole

    ça peut paraitre simple mais je vous promets que ca me facilitera la tâche

    En fait sur une requête j ai une serie d'ID que je voudrais récupérer

    Voici donc la requête:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    select * from ma table where ID IN ('00080ABE9',
    '00080ABQ2',
    '00083EAC3',
    '00083KAA3',
    '00083KAC9',
    '00087VAA5',
    '00089FAA8',
    '00175EAA6',
    '00253CHW0',
    '00432CBN0',
    '00432CCK5',
    '00432CDB4',
    '00432MAQ2',
    sauf que les id ne sont pas entre les '' avec la virgule il faut que que je les rajoute manuellement

    Sachant que j'en ai 10000 je vais perdre un temps fou a les rajouter

    Ma question est la suivante vous n aujriez une petite astuces pour rajouter les guillemets et la virgules automatiquement ?

    Je precise que les ID ont tous la meme longueur à savoir 9 caracteres alphanumériques

    je les copie / colle d'un fichier excel

    Merci encore de votre aide

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Transformez le fichier Excel en fichier csv. Chargez le fichier csv dans une table de travail via sqlloader. Réecrivez le Select pour utiliser la table de travail.

  3. #3
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    sachant que 10000 items dans la condition IN dépasse d'une part le nombre de max de la clause in et d'une part la taille max d'un ordre SQL.... donc il vaut mieux employer la méthode de mnitu
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

  4. #4
    Membre émérite
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 500
    Par défaut
    Et si tu générais des cellules calculées dans EXCEL à partir de tes cellules initiales en tapant la formule suivante :

  5. #5
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    cela ne sert à rien car l'ordre SQL résultant dépasserai dans tous les cas les 2 limites que j'ai cité

    Citation Envoyé par dgi77 Voir le message
    Et si tu générais des cellules calculées dans EXCEL à partir de tes cellules initiales en tapant la formule suivante :
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

  6. #6
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Mieux encore, utilisez une table externe à la place du sqlloader.

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 40
    Par défaut
    Merci beaucoup pour vos reponses

    je suis d accord que le max dans une requete sql est 1000 donc ca me bloque

    Je penses que le sqlloader peut être une bonne idée

    Après passer une table externe peut faciliter la chose mais la question comment faire ??

    Ne serait ce la requete avec .... from dual?

Discussions similaires

  1. Cherche fonction de traitement de chaine de caractere
    Par DeezerD dans le forum Langage
    Réponses: 1
    Dernier message: 10/09/2005, 15h41
  2. Traitement de chaine
    Par topolino dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 17/04/2005, 20h24
  3. [VB.NET] Traitement sur chaine (simple)
    Par Tempotpo dans le forum Windows Forms
    Réponses: 4
    Dernier message: 24/03/2005, 14h20
  4. [C#] Traitement de chaine
    Par david71 dans le forum Windows Forms
    Réponses: 13
    Dernier message: 03/03/2005, 17h29
  5. [CR]Traitement de chaines dans les formulas
    Par teckilax dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 05/07/2004, 10h01

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