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

MS SQL Server Discussion :

[SQL SERVER 2000] Comment créer une table "liée" ?


Sujet :

MS SQL Server

  1. #1
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    306
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 306
    Points : 71
    Points
    71
    Par défaut [SQL SERVER 2000] Comment créer une table "liée" ?
    Bonjour à tous,

    Voici mon problème :
    J'ai 2 BdD, sur le même serveur : BD1 et BD2.

    BD1 possède 2 tables : ARTICLE et COMMANDE.
    BD2 possède 1 table : ARTICLE (Différente de celle de BD1) et je voudrais faire une table liée sur COMMANDE de BD1, dans BD2.

    Il me semble que l'on peut faire cela avec Access sur une BdD SQL Server. Cela est-il possible dans SQL Server 2000 ? Comment pourrais-je faire ?

    Merci d'avance

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 056
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 056
    Points : 1 216
    Points
    1 216
    Par défaut
    Bonjour,

    il n'y a pas de table liée dans SQL Server. On parle de serveurs liés pour indiquer un serveur distant sur lequel on veut pouvoir exécuter une requête.

    Dans votre cas :

    Si vous être dans BD1 et que vous voulez accéder à la table ARTICLE de BD2 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select <cols>
    from COMMANDE A,
           BD2..COMMANDE B
    where etc.....
    Une autre solution pourrait être de créer une vue dans BD2 qui pointe sur commande dans BD2 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    create view COMMANDE as 
    SELECT <cols>
    from BD1..COMMANDE
    go
    Merci de préciser votre problème si cela ne répond pas à votre question.
    Emmanuel T.

  3. #3
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    306
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 306
    Points : 71
    Points
    71
    Par défaut
    Merci kagemaru pour ta réponse,

    Ce n'est pas si simple que cela.

    En fait j'ai un site web qui tourne sur BD1 j'affiche les articles de la table ARTICLE et j'enregistre les commandes dans la table COMMANDE.
    Dans le web.config de mon site je me connecte a BD1.
    Pas de soucis pour ce site.

    Le truc c'est que je veux un autre site (avec une autre adresse/domaine bien sur) connecté a BD2 qui affiche les articles de BD2.ARTICLE mais qui enregistre dans BD1.COMMANDE.
    Les 2 sites sont les même (dupliqué) mais chacun est connecté à ça base respective.
    Le truc c'est que je ne peux pas changer le code du site Web, c'est pour cela que si je pouvais connecter chaque site à une base et lier la table COMMANDE ca résoudrait mes problème

    J'espère que j'ai été clair ...

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 056
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 056
    Points : 1 216
    Points
    1 216
    Par défaut
    En effet, bcp plus clair par que le
    J'ai 2 BdD, sur le même serveur : BD1 et BD2
    ne disait pas vraiment ça . Par ailleurs, pour rendre les choses encore plus claires, merci de distinguer Serveur et base, un Serveur hébergeant N bases.

    Bref, il te faut donc un serveur lié (correspondant au serveur qui héberge BD2) sur le serveur hébergeant BD1 (Dans Enterprise Manager / Sécurité / Serveur liés).

    Pour tester que ça fonctionne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select count(*) from serveur_bd2.BD2..COMMANDE
    go
    Une fois créé, tu peux alors créer la vue dans la base BD1 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE VIEW COMMANDE AS 
    SELECT <cols>
    FROM serveur_bd2.BD2..COMMANDE
    go
    Emmanuel T.

  5. #5
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    306
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 306
    Points : 71
    Points
    71
    Par défaut
    Nikel, ca à l'air de fonctionner pas mal ainsi, en plus on peut même faire des insertions dans une vue.

    Merci beaucoup

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

Discussions similaires

  1. [SQL-SERVER 2000] Comment créer une sauvegarde ?
    Par bodev dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 03/10/2008, 15h06
  2. Réponses: 1
    Dernier message: 20/03/2007, 12h39
  3. [SQL SERVER 2005] comment créer une base de données ?
    Par Syrrus dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 13/03/2007, 14h26
  4. [C#/SQL Server 2005] Comment créer une base de donnée par le code ?
    Par FraktaL dans le forum Accès aux données
    Réponses: 4
    Dernier message: 09/09/2006, 17h27

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