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 MetaDB Get Table


Sujet :

MS SQL Server

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 64
    Points : 81
    Points
    81
    Par défaut SQL MetaDB Get Table
    Bonjour,

    J'ai une question SQL un peu difficile à poser, je vais essayer :

    j'aimerais faire un select * from X.

    ou X est une table dont je connais le nom au moment de l'execution.
    En fait j'ai une table MetaDB, et au moment de l'execution, s'il l'ID vaut 1 (table Users).

    Il va faire un select * from Users.

    Si ID=2 => select * from Articles.

    etc... si quelqu'un peu m'aider, ça sera avec plaisir

  2. #2
    Membre éprouvé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    623
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Août 2009
    Messages : 623
    Points : 1 049
    Points
    1 049
    Par défaut
    Essayez les requêtes dynamiques. Quelque chose comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    declare @SQL varchar(4000);
    declare @TABLE nvarchar(128);
    set @TABLE = 'matable';
    set @SQL = 'select * from ' + @TABLE
    exec(@SQL)

  3. #3
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Tout objet a un schéma, donc il faut le qualifier sinon vous laissez faire le boulot à SQL Server à chaque fois, et cela pénalise un peu les performances en plus d'être imprécis.

    D'autre part l'utilisation de sp_executesql @sql est plus recommandée que EXEC (@sql)

    @++

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 64
    Points : 81
    Points
    81
    Par défaut
    Citation Envoyé par elsuket Voir le message

    Tout objet a un schéma, donc il faut le qualifier sinon vous laissez faire le boulot à SQL Server à chaque fois, et cela pénalise un peu les performances en plus d'être imprécis.

    D'autre part l'utilisation de sp_executesql @sql est plus recommandée que EXEC (@sql)

    @++
    Tout d'abord merci darkelend ça marche nickel

    elsuket, peux-tu m'expliquer ce que tu veux dire pas "il faut le qualifier" ?
    peut-être avec un exemple.

    merci

  5. #5
    Membre éprouvé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    623
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Août 2009
    Messages : 623
    Points : 1 049
    Points
    1 049
    Par défaut
    Effectivement j'ai répondu très vite. Il vaut évidemment mieux utiliser ce script
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    declare @SQL nvarchar(4000);
    declare @TABLE nvarchar(128);
    declare @SCHEMA nvarchar(128);
    SET @SCHEMA = 'dbo'
    SET @TABLE = 'ma_table';
    SET @SQL = 'select * from ' + @SCHEMA + '.' + @TABLE
    execute sp_executesql @SQL
    Ce genre de chose fonctionne mais au niveau performance, ce n'est pas terrible car le plan d'exécution est recalculé à chaque fois. Donc à éviter si souvent utilisé.

  6. #6
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Merci Darkelend

    @++

Discussions similaires

  1. [PL/SQL][down&upLOAD] table document fixée
    Par meufeu dans le forum Oracle
    Réponses: 18
    Dernier message: 30/09/2004, 09h02
  2. [VB6 / SQL SEVER2000] Conseilssur table avec 80 000 enr ?
    Par Tankian dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 05/08/2004, 15h36
  3. PL/SQL Partager une table PL/SQL... possible ?
    Par Yorglaa dans le forum PL/SQL
    Réponses: 35
    Dernier message: 16/02/2004, 08h56
  4. A propos d'une requête SQL sur plusieurs tables...
    Par ylebihan dans le forum Langage SQL
    Réponses: 2
    Dernier message: 14/09/2003, 16h26
  5. [SQL] Remplacer une table
    Par rstephane dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/05/2003, 17h10

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