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

Langage SQL Discussion :

[SQL Server]Jointure ou non


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    250
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2006
    Messages : 250
    Points : 99
    Points
    99
    Par défaut [SQL Server]Jointure ou non
    Bonjour à tous ,

    J'ai deux tables comme ci contre:

    Status
    -Num_Status
    -Designation

    ET

    Historique
    -SecID
    -[...]
    -Ancien_Status
    -Nouveau_Status
    -[...]

    Mes données exemple :
    Status
    0 | Reception
    1 | Stock

    Historique
    PC_Num_1 | 0 | 1

    Je souhaiterai que ma requête me retourne le libellé contenus dans la table status dans historique :

    Resultat de la requête
    SecID | AncienStatus| NouveauStatus
    Pc_Num_1 | Reception | Stock

    Merci pour votre aide.

  2. #2
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    250
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2006
    Messages : 250
    Points : 99
    Points
    99
    Par défaut
    après avoir visualiser plusieurs requête j'ai pondu ceci :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT Serial, SecID, Date_Acte, Motif, AncienStatus, NouveauStatus, [User] ,
    	(Select Distinct Designation
    	 From StatusPC , HistoriquePC as HSPC 
    	 where Num_Status=  HSPC.AncienStatus
    	And SecID = 1) as Designation_Ancien_Status ,
        (Select Distinct Designation 
    	 From StatusPC as STPC, HistoriquePC as HSPC 
    	 where Num_Status=  HSPC.NouveauStatus
    	 And SecID = 1) as Designation_Nouveau_Status
    FROM HistoriquePC  
    Where SecID  = 1 
    Order by Serial
    Cela retourne ce que je souhaitai mais existe t-il un autre moyen peut être moins lourd que celui utilisé précédemment .

  3. #3
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    250
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2006
    Messages : 250
    Points : 99
    Points
    99
    Par défaut
    en fait ma requête précédente retourne une erreur dans la mesure ou la sous requête peut ne pas retourner qu'un seul résultat donc affaire à suivre ... Si un SQL Worker passe par la ...;
    Merci

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 571
    Points
    52 571
    Billets dans le blog
    5
    Par défaut
    Quel lien logique et sémantique y a t-il entre les tables status et historique ?

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Membre régulier
    Inscrit en
    Janvier 2006
    Messages
    250
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2006
    Messages : 250
    Points : 99
    Points
    99
    Par défaut
    Bonjour merci de vous pencher sur mon problème ,

    Les deux tables sont construite de la manière suivante :

    A un Status dans la table PC correspond un Num_Status dans la table Status.

Discussions similaires

  1. [SQL Server 2000] Caractere non toléré
    Par nox75 dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 07/10/2007, 10h54
  2. SQL Server 2000 :demarrage non-administrateur
    Par maxtin dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 23/07/2007, 16h16
  3. [SQL Server] jointure externe et SUM
    Par TangoZoulou dans le forum Langage SQL
    Réponses: 6
    Dernier message: 07/11/2006, 15h13
  4. [SQL Server] "Jointure" avec histo inexistant
    Par Tankian dans le forum Langage SQL
    Réponses: 4
    Dernier message: 08/09/2006, 14h49
  5. [SQL Server] Jointure entre 2 tables et performances
    Par rmeuser dans le forum Langage SQL
    Réponses: 3
    Dernier message: 27/04/2006, 10h12

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