Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

LISTE DES BASES,TABLES ET COLONNES TRIÉS PAR TYPE (PROCEDURE STOCKÉS,VUES,TABLES UTLISATEUR,TABLES SYSTEME ETC....)


Information sur la source

Catégorie :Divers Classé sous : liste, base, table, colonne, tri Niveau : Débutant Date de création : 03/10/2005 Date de mise à jour : 03/10/2005 16:47:07 Vu : 6 121

Note :
8 / 10 - par 1 personne
8,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (3)
Ajouter un commentaire et/ou une note

Description

Ce code liste a l'aide d'un curseur liste la base de donnée d'un serveur SQL sur IIS
il doit etre possible de le rendre plsu rapide en evitant le curseur je n'ai pas encore trouvé,
voici donc une methode qui permet de lister le tout a partir d'un curseur,
je mettrais ma source a jour si je trouve le moyen de le faire sans passer par le curseur car pour l'insatnt c'est un peu long des que la base de donnée devient importante.
En tout cas peut etre utile pour dresser un tree view de la base de donnée a condition de ne pas avoir une trop grosse base de donnée.
 

Source

  • /*Petite Mise a Jour : Cette requete fait la meme Chose que le curseur du dessous mais la fonction sp_Msforeachhdb n'est pas documentée dans SQL server donc a utliser avec precaution*/
  • exec sp_Msforeachdb 'SELECT ''?'' as nameBase,O.name as nameTable,O.TYPE,C.name as nameColumn FROM "?".dbo.sysobjects O LEFT JOIN "?".dbo.syscolumns C on C.id=O.id'
  • rem : le ? remplace le nom des bases de données, la fonction sp_Msforeachdb remplace elle meme le ? par le nom de toutes les Tables
  • /*Meme Chose mais avec curseur (10* plus lent)*/
  • DECLARE C_Base CURSOR
  • FOR
  • SELECT
  • B.name AS NomBase,
  • B.dbid AS IdBase
  • FROM
  • master.dbo.sysdataBases B
  • LEFT JOIN master.dbo.sysobjects O
  • on O.id=B.dbid
  • DECLARE @Base as varchar(50)
  • DECLARE @Id as int
  • DECLARE @SQL as varchar(5000)
  • declare @Tri as int
  • DECLARE @i as int
  • SET @i=0
  • SET @SQL='SELECT maBase,nameTable,nameColumn,
  • NomType=
  • CASE type
  • WHEN ''U'' THEN ''Tables Utilisateur''
  • WHEN ''FN'' THEN ''Fonctions''
  • WHEN ''P'' THEN ''Procedure Stockée''
  • WHEN ''S'' THEN ''Tables Systemes''
  • WHEN ''TR'' THEN ''Triggers''
  • WHEN ''V'' THEN ''VUES''
  • ELSE ''Autre''
  • END,
  • Tri=
  • CASE type
  • WHEN ''U'' THEN ''1''
  • WHEN ''FN'' THEN ''5''
  • WHEN ''P'' THEN ''4''
  • WHEN ''S'' THEN ''2''
  • WHEN ''TR'' THEN ''6''
  • WHEN ''V'' THEN ''3''
  • ELSE 7
  • END FROM ('
  • OPEN C_Base
  • FETCH C_Base INTO @Base,@Id
  • WHILE @@FETCH_STATUS = 0
  • BEGIN
  • IF @i>0
  • BEGIN
  • SET @SQL = @SQL + ' UNION '
  • END
  • SET @SQL = @SQL + ' SELECT ''' + @Base + ''' as maBase,O.name as nameTable,O.TYPE,C.name as nameColumn FROM [' + @Base + '].dbo.sysobjects O LEFT JOIN [' + @Base + '].dbo.syscolumns C on C.id=O.id'
  • SET @i=@i+1
  • FETCH C_Base INTO @Base,@Id
  • END
  • CLOSE C_Base
  • DEALLOCATE C_Base
  • SET @SQL= @SQL + ')AS NewVue ORDER BY maBase,Tri,nameTable,NameColumn'
  • exec(@SQL)
/*Petite Mise a Jour : Cette requete fait la meme Chose que le curseur du dessous mais la fonction sp_Msforeachhdb n'est pas documentée dans SQL server donc a utliser avec precaution*/

exec sp_Msforeachdb 'SELECT ''?'' as nameBase,O.name as nameTable,O.TYPE,C.name as nameColumn FROM "?".dbo.sysobjects O LEFT JOIN "?".dbo.syscolumns C on C.id=O.id'

rem : le ? remplace le nom des bases de données, la fonction sp_Msforeachdb remplace elle meme le ? par le nom de toutes les Tables

/*Meme Chose mais avec curseur (10* plus lent)*/
DECLARE C_Base CURSOR 
FOR 
	SELECT
	      B.name AS NomBase,
	      B.dbid AS IdBase
	FROM 
	      master.dbo.sysdataBases B
	      LEFT JOIN master.dbo.sysobjects O
	      on O.id=B.dbid

DECLARE @Base as varchar(50)
DECLARE @Id as int
DECLARE @SQL as varchar(5000)
declare @Tri as int
DECLARE @i as int

SET @i=0
SET @SQL='SELECT maBase,nameTable,nameColumn,
		 NomType=
      		     CASE type
         		WHEN ''U'' THEN ''Tables Utilisateur''
         		WHEN ''FN'' THEN ''Fonctions''
         		WHEN ''P'' THEN ''Procedure Stockée''
         		WHEN ''S'' THEN ''Tables Systemes''
         		WHEN ''TR'' THEN ''Triggers''
			WHEN ''V'' THEN ''VUES''
         		ELSE ''Autre''
      		     END,
	   	 Tri=
		     CASE type
			WHEN ''U'' THEN ''1''
			WHEN ''FN'' THEN ''5''
			WHEN ''P'' THEN ''4''	
			WHEN ''S'' THEN ''2''	
			WHEN ''TR'' THEN ''6''
			WHEN ''V'' THEN ''3''
			ELSE 7
			END FROM ('

OPEN C_Base
FETCH C_Base INTO @Base,@Id
	WHILE @@FETCH_STATUS = 0
	BEGIN
		IF @i>0 
		BEGIN
			SET @SQL = @SQL + ' UNION '
		END
		SET @SQL = @SQL + ' SELECT ''' + @Base + ''' as maBase,O.name as nameTable,O.TYPE,C.name as nameColumn FROM [' + @Base + '].dbo.sysobjects O LEFT JOIN [' + @Base + '].dbo.syscolumns C on C.id=O.id'
	SET @i=@i+1
	FETCH C_Base INTO @Base,@Id
	END
CLOSE C_Base
DEALLOCATE C_Base
SET @SQL= @SQL + ')AS NewVue ORDER BY maBase,Tri,nameTable,NameColumn'
exec(@SQL)

Historique

03 octobre 2005 16:47:08 :
Ajout d'une methode Sans curseur 10* plus rapide (2s contre 20 avec le curseur sur ma base de données)

Commentaires et avis

signaler à un administrateur
Commentaire de fabrice69 le 27/10/2005 23:52:37 administrateur CS

Intéressant.
je ne connaissais pas la fonction présentée en premier plan.
Romelard Fabrice

signaler à un administrateur
Commentaire de zekabyle le 27/04/2006 18:29:32

j'utilise deux bases "portefeuille" sur access dans le même dossier et je veux faire une liaison dynamique entre ces deux bases pour pouvoir utiliser les tables selon leur propre base.
Comment faire?
merci

signaler à un administrateur
Commentaire de crilun le 28/04/2006 14:53:10

tu peut expliquer plus je voit pas tres bien ce que tu veut faire?
si tu pouvais donner un exemple ocncret de ce que tu veut faire je pourrais peut etre te repondre mais la je vois pas trop ce que tu veut faire???

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

Nom d'une colonne [ par NoOneElse ] salut,je développe une application de traçage d'une base de donnée Oracle où je peut crée des TRIGGER a partir d'un nom d'une table existe dans la bas je ne peu plus afficher le contenu d'une table [ par abdoo05 ] salut, j'ai crée un pg avec java qui permet d'afficher le contenu d'une table de base de donnée... mais le pb est que ma table est trop chargé et je n Entrer des valeurs différentes dans une colonne [ par DjanGoJack ] Bonjour a tous,Ma base de données sql regroupe tous les patients d'un hopital et tous les examens qu'ils ont eus.Je dispose d'une table sql nommé ANTE Recherche de doublon dans plusieurs champs d'une même table [ par PtitBilou ] Bonjour ! Fraichement larguée par mon employeur dans les méandres de la base de donnée, j'essaie de me dépatouiller pour mettre en place une base de d Besoin d'aide avecUPDATE et BOUCLE [ par johann36 ] Bonjour,J'ai un gros soucis et je bloque dessus depuis ce matin sans trouver la réponse.J'essaie de faire une boucle avec une requête UPDATE, je m'exp changer valeur d'une colonne dans une base de donnée ODBC [ par ju0123456789 ] HelloPourriez-vous me dire quelle est la commande pour changer la valeur d'une colonne dans une base de donnée type ODBC, sa valeur par défaut étant F select sur une liste de clef [ par JulienOrion666 ] Bonjour, Voila j'ai une liste de clef correspondant a des personnes d'une table et je veux tous les selectioner je les ai ds un tableau et quand je l Base MySQL et Index [ par MadM@tt ] Bonjour à tous,J'ai quelques question concernant les Index dans une table SQL.Est-il utile de les mettre sur des champs enum (Par exemple sur un champ Pivot [ par celinette85 ] Bonjour, Est-il possible de créer un pivot dans une base développée sous ACCESS 2000 ?J'ai essayé avec la structure  :Transformm count (table.colonne) base de donnee [ par wahdani2007 ] slt pour ttes je veut une base de donnee complet pour une gestion de stock avec les requêtes possibles d'une sté (achat et vente des matreriels infos)


Nos sponsors

Sondage...

CalendriCode

Janvier 2009
LMMJVSD
   1234
567891011
12131415161718
19202122232425
262728293031 

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,374 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.