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 :

Obtenir des informations sur table temporaire


Sujet :

MS SQL Server

  1. #1
    Membre régulier

    Profil pro
    Inscrit en
    Mars 2006
    Messages
    90
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 90
    Points : 114
    Points
    114
    Par défaut Obtenir des informations sur table temporaire
    Je souhaiterais savoir s'il est possible d'obtenir des informations sur les tables temporaires #table, comme par exemple le nom de champs. Merci

    PS : j'utilise SQL Server 2000

  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
    SELECT t.TABLE_NAME, c.COLUMN_NAME
    FROM tempdb.INFORMATION_SCHEMA.TABLES t
    JOIN tempdb.INFORMATION_SCHEMA.COLUMNS c ON t.TABLE_NAME = c.TABLE_NAME
    WHERE TABLE_TYPE = 'BASE TABLE'
    ORDER BY t.TABLE_NAME

  3. #3
    Membre régulier

    Profil pro
    Inscrit en
    Mars 2006
    Messages
    90
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 90
    Points : 114
    Points
    114
    Par défaut
    Merci beaucoup pour la reponse. Ce que tu m'a donne ne fonctionnait pas dans mon cas mais m'a permis de resoudre mon probleme puisque la requete me renvoyait un set vide (en ayant bien sur modifie la valeur BASE TABLE). En effet, il fallait aller chercher dans la base tempdb.

    Voici ce que je voulais faire et comment je m'y suis pris. Je cree la table temporaire suivante (dans une procedure stockee par exemple) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      CREATE TABLE #table1 (
        nom varchar(80),
        age int
      )
    On peut trouver les informations concernant cette table temporaire dans tempdb. Cependantm le nom de la table n'est pas '#table1' mais un truc du genre '#table1____________________________________________'

    Donc pour recuperer les champs de cette table, j'ai utilise la requete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    use tempdb
    select O.name, C.name, C.colid, T.name, C.length
    from sysobjects O, syscolumns C, systypes T
    where O.xtype = 'U'
      and O.id = C.id
      and T.xtype = c.xtype
      and O.Name like '#table1___________%'
    order by O.name, C.colid
    et voila. Puis pour avoir le nombre de champs, suffit de compter.

    Bref, merci beaucoup de ton aide !! A bientot !

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

Discussions similaires

  1. Obtenir des informations sur l'ordinateur
    Par Shredder dans le forum Langage
    Réponses: 0
    Dernier message: 06/07/2008, 00h41
  2. Réponses: 2
    Dernier message: 18/03/2008, 13h58
  3. Obtenir des informations sur un fichier
    Par Just dans le forum Langage
    Réponses: 1
    Dernier message: 19/02/2008, 10h42
  4. Réponses: 1
    Dernier message: 30/01/2008, 16h42
  5. Comment obtenir des informations sur le serveur?
    Par Me,Myself and I dans le forum ASP.NET
    Réponses: 2
    Dernier message: 16/01/2007, 09h36

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