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 :

insert imbriqués sur plusieurs tables


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    88
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 88
    Points : 64
    Points
    64
    Par défaut insert imbriqués sur plusieurs tables
    Bonjour,

    je voudrais savoir comment optimiser mes requetes d'insertion...
    (voir si qqun peut me conseiller un tuto sympa sur l'optimisation des requetes SQL)

    J'ai 2 tables:
    Table 1:
    T_PAYS avec nom de colonnes (PAYS_CODE,PAYS_LABEL,PAYS_LANGUE)
    exemple enregistrement: 'FR','FRANCE','Français'
    PAYS_CODE étant la clé primaire

    Table 2:
    T_PERSONNE (PE_MAT,PE_NOM,PE_PAYS)

    je voudrais en une seule requete recuperer PAYS_CODE pour l'inserer dans PE_PAYS

    une requete du genre:

    insert into
    T_PERSONNE
    (PE_MAT,PE_NOM,PE_PAYS) values
    ('papaw', 'papawemba', SELECT PAYS_CODE from T_PAYS where PAYS_LABEL='FRANCE');

    est ce correct????


    et si oui on peut faire ça sur plusieurs tables???
    genre rajouter un champ PE_SERVICE dans T_PERSONNE et rebelotte

    insert into
    T_PERSONNE
    (PE_MAT,PE_NOM,PE_PAYS,PE_SERVICE) values
    ('papaw', 'papawemba', SELECT PAYS_CODE from T_PAYS where PAYS_LABEL='FRANCE',SELECT SERV_ID from T_SERVICE where SERV_LABEL='Info');


    PS: il m'avais semblé voir il ya environ 2 ans qqes chose de sympa avec des instructions TYPE..(à vérifier) qui insérer dans les tables annexes (dans mon cas T_PAYS, T_SERVICE) avant de retourner la clé et de l'insérer dans la table "mère" : T_PERSONNE
    Mais impossible de retomber dessus...

  2. #2
    Expert confirmé
    Avatar de rudib
    Homme Profil pro
    Fakir SQL Server & NoSQL
    Inscrit en
    Mai 2006
    Messages
    2 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Fakir SQL Server & NoSQL

    Informations forums :
    Inscription : Mai 2006
    Messages : 2 573
    Points : 4 043
    Points
    4 043
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    insert into dbo.T_PERSONNE
    (PE_MAT,PE_NOM,PE_PAYS,PE_SERVICE) 
    SELECT 'papaw', 'papawemba', PAYS_CODE, (SELECT TOP 1 SERV_ID from dbo.T_SERVICE where SERV_LABEL='Info')
    from dbo.T_PAYS 
    where PAYS_LABEL='FRANCE'

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

Discussions similaires

  1. [AC-2000] INSERT INTO sur plusieurs table
    Par Fr33dom dans le forum Requêtes et SQL.
    Réponses: 13
    Dernier message: 03/02/2011, 10h14
  2. INSERT INTO sur plusieurs tables
    Par FMDCC dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 05/02/2010, 10h41
  3. INSERT INTO sur plusieurs tables
    Par Thierry8 dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 12/02/2006, 15h26
  4. DELETE imbriqués sur plusieurs tables ?
    Par Oberown dans le forum Langage SQL
    Réponses: 8
    Dernier message: 29/07/2005, 14h53
  5. INSERT sur plusieurs tables
    Par juniorAl dans le forum Langage SQL
    Réponses: 4
    Dernier message: 30/03/2005, 18h59

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