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

Développement SQL Server Discussion :

Joindre 2 Vues en une seule


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Fiona08
    Inscrit en
    Juillet 2008
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 108
    Par défaut Joindre 2 Vues en une seule
    Salut à tous,
    J'aimerai reunir 2 vues pour en faire une seule, mais je ne sais pas comment proceder.
    soit les 2 vues suivantes v_Dispo1 et v_Dispo2(code voir ci-dessous). J'aimerai les reunir pour avoir v_Dispo3 contenant les colonnes suivantes et sans doublure de données:
    Colonnes v_Dispo3:
    anlID| anlBez|ligneID| ligneBez|PlanW|IstTempsDispo|IST2009|Mois| Annee

    La colonnes mois de v_Dispo3 doit etre une union des colonnes Mois de v_Dispo1, Mois et 13Mois de v_Dispo2.

    Comment faire? Est-ce que quelqu'un a une methode plus facile?

    Code des Vues
    Table v_Dispo1
    anlID| anlBez| PlanW| ligneID| ligneBez| Mois| Annee
    ---code v_Dispo1--
    create view v_Dispo1 as
    select donneeMois.anl_id as anlID,
    anl.bez as anlBez,
    donneeMois.NonDispo as PlanW,
    ligne.ligne_id as ligneID,
    ligne.bez as ligneBez,
    SUBSTRING(CONVERT(varchar, donneeMois.validite, 110), 1, 2) as Mois,
    SUBSTRING(CONVERT(varchar, donneeMois.validite, 110), 7, 10) as Annee

    from donneeMois, anl, ligne
    where donneeMois.anl_id = anl.anl_id
    and anl.anl_id = ligne.anl_id


    ---Colonnes v_Dispo2---
    v_Dispo2
    DonneeLigneID|linieID|ligneBez|ligneID|Mois|Annee|IstTempsDispo|IST2009|13Mois

    --Code v_Dispo2--
    create view v_Dispo2 as
    select DonneeLigne.DonneeLigne_id as DonneeLigneID,
    DonneeLigne.ligne_id as linieID,
    linie.bez as ligneBez,
    SUBSTRING(CONVERT(varchar, DonneeLigne.validite, 110), 1, 2) as Mois,
    SUBSTRING(CONVERT(varchar, DonneeLigne.validite, 110), 7, 10) as Annee,
    tempsDispo.ist as IstTempsDispo,
    tempsDispo.haut as IST2009,
    '13' as 13Mois

    from DonneeLigne, ligne, tempsDispo

    where ligne.ligne_id = DonneeLigne.ligne_id
    and DonneeLigne.DonneeLigne_id = tempsDispo.DonneeLigne_id


    Aidez moi svp, car je suis debutante en ce qui concerne le sql.

    Merci d'avance
    Fiona

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 249
    Par défaut
    Ta vue 1 a une organisation de colonnes differentes de ta vue 2, par conséquent, dans l'état, tu ne peux pas faire un UNION.

    Pour faire un UNION, tu dois avoir l'organisation suivante

    SELECT (champs1) AS Titre1,(Champs2) AS Titre2,(Champs3) As Titre3
    UNION
    SELECT (Champs4) AS Titre1,(Champs5) AS Titre2,(Champs6) AS Titre3

    Champs1 et Champs4 doivent être du meme type de données.
    Champs2 et Champs5 doivent être du meme type de données.
    Champs3 et Champs6 doivent être du meme type de données.

    Revoie un peu ta copie, organise tes vues!

  3. #3
    Membre confirmé Avatar de Fiona08
    Inscrit en
    Juillet 2008
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 108
    Par défaut
    salut ylarvor,

    biensûr les 2 vue ont des colonnes differentes et je dois les réunir en une seule. Mais je ne sais comment faire. Je ne peux cahnger la structure, car c'est ce que j'ai eu comme table et le but est l'union des 2 vues.

    Est-ce qu'il ya úne methode autre que union pour reunir 2 table avec des collones differentes?

    Merci d'avance
    fiona

  4. #4
    Membre Expert

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 249
    Par défaut
    Il n'existe que deux mécanismes en SQL que tu pourrais appliquer, l'union et la jointure... Aucun des 2 ne te permet de créer une vue résultat!

    On ne mélange pas les torchons et les serviettes, tes vues n'ont rien en commun!

    Desole.

  5. #5
    Membre Expert

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Août 2007
    Messages : 1 216
    Par défaut
    Bonjour Fiona,

    Tu peux penser à utiliser des artifices afin de creer une vue unique.
    J'appele artifice le fait d'inserer manuellement un champs dans le select d'une vue ou de l'autre.

    Je vais prendre un exemple à 2 colonnes pour rester simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    create view v1 as
    select cast(x as varchar), cast(y as int)
    from table 1
     
    create view v2 as
    select cast(w as varchar)
    from table 2
    A priori, il sera pas possible de faire un union vu la différence de nombre de colonne.

    Par contre tu peux faire ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    create view3 as
     
    select x,y from v1
    union
    select w,0 from view 2
    Ici, tu utilises une valeur arbitraire préalablement définie (dans ce cas le 0) et je dirais, hors du champs des valeurs possibles pour ne pas polluer tes infos avec de fausses informations.

    Tu peux très bien "combler" cela avec une chaine de caracteres vide par exemple, si la colonne à "combler" est de type varchar ou char.

    Et pour en revenir à ton cas, union ce qui peut l'etre et crée des dummy pour les colonnes incompatibles


    NB : ou organiser tes colonnes dans ton select pour creer la vue 3 afin d'avoir les meme noms des vues 1 et 2 allignés et pas de faire de mélange de type. A utiliser de toute facon à la place de select * from v1 union select * from v2.

  6. #6
    Membre confirmé Avatar de Fiona08
    Inscrit en
    Juillet 2008
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 108
    Par défaut
    Salut Ptit_Dje,

    grand merci pour ton aide. J'ai suivi le cheminement et j'ai eu la reponse que je voulais.

    Fiona08

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

Discussions similaires

  1. Joindre 2 tables en une seule
    Par Arnaud F. dans le forum Langage SQL
    Réponses: 12
    Dernier message: 25/11/2008, 21h20
  2. Réponses: 4
    Dernier message: 26/12/2007, 14h50
  3. Créer plusieurs tables identiques vues comme une seule
    Par maqfab dans le forum Langage SQL
    Réponses: 3
    Dernier message: 11/10/2007, 11h41
  4. Joindre plusieurs tables pour en former qu'une seule.
    Par timeout dans le forum Requêtes
    Réponses: 7
    Dernier message: 19/09/2005, 09h18
  5. Joindre 2 colonnes pour en afficher une seule
    Par major2 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 04/04/2005, 15h17

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