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

Développement SQL Server Discussion :

[SQL Server 2000] Nombre d'enregistrements dans toutes les tables utilisateur


Sujet :

Développement SQL Server

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    72
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 72
    Points : 48
    Points
    48
    Par défaut [SQL Server 2000] Nombre d'enregistrements dans toutes les tables utilisateur
    Bonjour,

    J'aurais besoin d'aide pour écrire la requete pour m'afficher le nombre d'enregistrements dans chaque table utilisateur avec colonne 1 = nom de la table et colonne 2 = nbre d'enregistrement.

    Merci d'avance

    David

  2. #2
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    Cette requête je l'utilise pour auditer les tables, objectif : purger
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    USE msdb 
    GO 
    IF OBJECT_ID('dbo.T_AUDIT_TABLES', 'U') IS NOT NULL 
      DROP TABLE dbo.T_AUDIT_TABLES 
    GO 
    CREATE TABLE msdb.dbo.T_AUDIT_TABLES 
      ( 
      [NomTable] nvarchar(20), 
      [NbLignes] char(11) NULL, 
      [EspacePrevu] varchar(18) NULL, 
      [TailleData] varchar(18) NULL, 
      [TailleIndex] varchar(18) NULL, 
      [EspaceInutilise] varchar(18)  
      ) ON [PRIMARY] 
    GO 
    -- Se positionner sur la base à auditer  
    USE [TaBase]  
    GO 
    DECLARE @TabEnCoursTraitement VARCHAR(50),@SQL VARCHAR (100), @DEL VARCHAR (100) 
    -- Stocker le nom des tables de la base dans une table temporaire 
    CREATE TABLE #LIST_TABLES (nom_table varchar (50)) 
    INSERT INTO #LIST_TABLES  
    SELECT TABLE_SCHEMA+'.'+TABLE_NAME AS [NomTable] 
    FROM information_schema.tables 
    WHERE table_type='BASE TABLE' 
    ORDER BY [NomTable] 
    -- Tant qu'il y a des lignes dans la table temporaire 
    WHILE EXISTS ( SELECT nom_table  
      FROM #LIST_TABLES 
      )  
    BEGIN 
    --Se positionner sur la 1ère ligne de la table temporaire 
    SET @TabEnCoursTraitement = (SELECT TOP 1 nom_table FROM #LIST_TABLES) 
    -- Insérer les infos de la table en cours de traitement dans la table qui stocke les infos à auditer  
    SET @SQL = 'INSERT INTO msdb.dbo.T_AUDIT_TABLES EXEC sp_spaceused '''+ @TabEnCoursTraitement + ''';' 
    EXEC (@SQL);  
    -- Supprimer la table traitée de la table temporaire 
    SET @DEL = 'DELETE FROM #LIST_TABLES WHERE nom_table = '''+ @TabEnCoursTraitement + ''';' 
    EXEC (@DEL) 
    END 
    --Supprimer la table temporaire 
    DROP TABLE #LIST_TABLES 
     
    --> Quelles sont les 10 tables ayant le plus de lignes
     
    SELECT TOP 10 NomTable 
    , cast([NbLignes] as int) AS [Nombre de Lignes] 
    FROM msdb.dbo.T_AUDIT_TABLES 
    ORDER BY [Nombre de Lignes] DESC 
     
    --> Quelles sont les 10 tables les plus grosses
    SELECT TOP 10 NomTable 
    , cast(replace([TailleData],'KB','') as int) AS [TailleData (en Ko)] 
    , cast(replace([TailleIndex],'KB','') as int) AS [TailleIndex (en Ko)] 
    ,cast(replace([EspacePrevu],'KB','') as int) AS [EspaceReservé (en Ko)] 
    ,cast(replace([EspaceInutilise],'KB','') as int) AS [EspaceInutilisé (en Ko)] 
    FROM msdb.dbo.T_AUDIT_TABLES 
    ORDER BY [TailleData (en Ko)] DESC
    Pour plus de détails
    Etienne ZINZINDOHOUE
    Billets-Articles

  3. #3
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 577
    Points
    52 577
    Billets dans le blog
    5
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    DECLARE @SQL VARCHAR(max);
    SET @SQL = '';
    SELECT @SQL = @SQL + 'SELECT COUNT(*) AS N, ''' + TABLE_SCHEMA + '.' 
              +  TABLE_NAME +''' AS NOM_TABLE FROM ' 
           + TABLE_SCHEMA + '.' + TABLE_NAME +' UNION ALL '
    FROM   INFORMATION_SCHEMA.TABLES
    WHERE  TABLE_TYPE = 'BASE TABLE'       
    SET @SQL = SUBSTRING(@SQL, 1, LEN(@SQL) - 10)
    EXECUTE (@SQL)
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  4. #4
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DECLARE @SQL VARCHAR(max);
    A +
    Il me semble que SQL 2000 n'accepte pas varchar (max).

    En remplaçant varchar (max) par varchar(8000) on obtient bien le résultat excompté.
    Etienne ZINZINDOHOUE
    Billets-Articles

  5. #5
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    J'ai ajouté un tri sur le script de sqlpro

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    DECLARE @SQL VARCHAR(8000);
    SET @SQL = '';
    SELECT @SQL = @SQL + 'SELECT COUNT(*) AS N, ''' + TABLE_SCHEMA + '.' 
              +  TABLE_NAME +''' AS NOM_TABLE FROM ' 
           + TABLE_SCHEMA + '.' + TABLE_NAME +' UNION ALL '
    FROM   INFORMATION_SCHEMA.TABLES
    WHERE  TABLE_TYPE = 'BASE TABLE'   
    SET @SQL = SUBSTRING(@SQL, 1, LEN(@SQL) - 10) + ' ORDER BY N DESC'
    EXECUTE (@SQL)
    Etienne ZINZINDOHOUE
    Billets-Articles

  6. #6
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    72
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 72
    Points : 48
    Points
    48
    Par défaut
    Merci à tous!

    David

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

Discussions similaires

  1. Connaitre le nbr d'enregistrement dans toutes les tables de la base
    Par lolafrite dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 30/10/2008, 16h32
  2. Nombre d'enregistrement sur toute les tables ?
    Par lolafrite dans le forum SQL
    Réponses: 2
    Dernier message: 30/10/2008, 15h22
  3. Réponses: 1
    Dernier message: 06/08/2007, 11h02
  4. [SQL] Problème avec nombre d'enregistrements dans une table
    Par zana74 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 14/08/2006, 13h28
  5. [SQL Server 2000] exclusion dernière date dans un between?
    Par biloumousse dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 03/04/2006, 17h11

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