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 Oracle Discussion :

un minus embêtant


Sujet :

SQL Oracle

Vue hybride

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 29
    Par défaut un minus embêtant
    Bonjour à tous,

    dites j'ai une liste de données qui me viennent sous la forme:
    "donnee1, donnee2, donnee3"

    et j'aimerais savoir laquelle de ces données ne se trouve pas dans un certain champ d'une table.

    j'aurais aimé pouvoir faire:

    select donnee1, donnee2, donnee3 from dual
    minus
    select champ1 from table1

    mais ça ne marche pas parceque les données de la première partie se classent en colonne plutôt qu'en ligne. J'ai pensé à faire :


    select donnee1 from dual union
    select donnee2 from dual union
    select donnee3 from dual minus
    select champ1 from table1

    et là ça marche même s'il m'a fallu couper ma chaine pour récupérer donnee1, donnee2 et donnee3. Est-ce que quelqu'un aurait une autre idée ?


    Merci d'avance

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 60
    Par défaut
    Bonjour,

    merci d'indiquer la version Oracle utilisée.

    sinon, tu peux essayer quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    create type varchar2_table as table of VARCHAR2(100);
    select * from table(varchar2_table('donnee1', 'donnee2', 'donnee3'))
    mise en ligne de tes valeurs, puis tu peux faire ton minus dessus.

  3. #3
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    quel intérêt? select from dual union va très bien!

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 60
    Par défaut
    C'est juste pour éviter de découper la chaine et de construire son SQL dynamiquement en fonction du nombre de valeurs découpées.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE type varchar2_table AS TABLE of VARCHAR2(100);
    SELECT * FROM TABLE(varchar2_table('donnee1', 'donnee2', 'donnee3'))
    minus
    select champ1 from table1
    Il suffit de remplacer 'donnee1', 'donnee2','donnee3' par la liste des valeurs sans besoin de faire du découpage et de la reconstruction du SQL

  5. #5
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    tu découpes aussi 'donnee1,donnee2,donnee3' en en 'donnee1', 'donnee2', 'donnee3', non?

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    29
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 29
    Par défaut
    Trop cool Zugg, ça déchire ton truc.
    En plus je compare des nombres donc je n'aurais pas à mettre d'apostrophes.

    Par contre si ton type table avait plusieurs champs (colonnes) comment aurais-tu fais pour ajouter plusieurs lignes à ta table ?

    Est-ce que ceci aurait marché par exemple

    SELECT * FROM TABLE(varchar3_table(('donnee1', 'donnee2'), ('donnee3', 'donnee4') ))
    avec les parenthèses pour délimiter les lignes ??? déjà au niveau de create type comment aurait-on renseigné les types de champs ??

Discussions similaires

  1. Réponses: 1
    Dernier message: 21/01/2006, 18h00
  2. Minus?
    Par xVINCEx dans le forum Access
    Réponses: 3
    Dernier message: 24/11/2005, 15h19
  3. la clause MINUS ne fonctionne pas
    Par requiemforadream dans le forum ASP
    Réponses: 5
    Dernier message: 29/04/2005, 15h41
  4. équivalant de la commande MINUS en MySQL
    Par El Saigneur dans le forum Requêtes
    Réponses: 7
    Dernier message: 01/09/2004, 17h03
  5. [SQLServer][Minus] Ca marche pas ???
    Par TheRussian dans le forum Langage SQL
    Réponses: 3
    Dernier message: 01/04/2004, 15h55

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