While Loop to Iterate through Databases

后端 未结 7 1201
暖寄归人
暖寄归人 2021-02-05 13:05

I was wondering if someone could help me with creating a while loop to iterate through several databases to obtain data from one table from two columns. this is was I have done

相关标签:
7条回答
  • 2021-02-05 13:29

    I would consider sp_MSForEachDB which is a lot easier...

    Edit:

    EXEC sp_MSForEachDB 'USE [?]; IF DB_NAME() LIKE ''Z%%''
    BEGIN
    
    
    END
    '
    
    0 讨论(0)
  • 2021-02-05 13:30
    CREATE TABLE #T
    (dbname sysname NOT NULL PRIMARY KEY,
    SumPGCOUNT INT,
    CREATED DATETIME)
    
    DECLARE @Script NVARCHAR(MAX) = ''
    
    SELECT @Script = @Script + '
    
    USE ' + QUOTENAME(name) + '
    IF EXISTS(SELECT * FROM sys.tables WHERE OBJECT_ID=OBJECT_ID(''dbo.tbldoc''))
      INSERT INTO #T
      SELECT db_name() AS dbname, SUM(PGCOUNT) AS SumPGCOUNT, CREATED 
      FROM dbo.tbldoc
      GROUP BY CREATED;  
      '
    FROM sys.databases 
    WHERE state=0 AND user_access=0 and has_dbaccess(name) = 1
     AND [name] like 'z%' and create_date between '2010-10-17' and '2011-01-15'
    ORDER BY [name]
    
    IF (@@ROWCOUNT > 0)
     BEGIN
     --PRINT @Script
     EXEC (@Script)
     SELECT * FROM #T
     END
    
     DROP TABLE #T
    
    0 讨论(0)
  • 2021-02-05 13:41
    DECLARE @Loop int
    DECLARE @MaxLoop int
    DECLARE @DBName varchar(300)
    DECLARE @SQL varchar(max)
    
    SET @Loop = 1
    SET @DBName = ''
    
    set nocount on
    SET @MaxLoop =  (select count([name]) FROM sys.databases where [name] like 'Z%')
    WHILE @Loop <= @MaxLoop
        BEGIN
            SET @DBName = (select TableWithRowsNumbers.name from (select ROW_NUMBER() OVER (ORDER by [name]) as Row,[name] FROM sys.databases where [name] like 'Z%' ) TableWithRowsNumbers where Row = @Loop)
            SET @SQL = 'USE [' + @DBName + ']'
            exec (@SQL)
            ...
            ...
            set @Loop = @Loop + 1
        END
    

    ***Note: I didn't add the check if exists here.

    0 讨论(0)
  • 2021-02-05 13:43

    You don't have to use a "USE DATABASE" statement. You can select from the particular database table by using a 3 part identifier as in:

    select * from MyDatabase.dbo.MyTable

    0 讨论(0)
  • 2021-02-05 13:48

    My code to search for data from more than one database would be:

    use [master]
    
    go
    
    if object_id('tempdb.dbo.#database') is not null 
    
        drop TABLE #database
    
    go
    
    create TABLE #database(id INT identity primary key, name sysname)
    
    go
    
    set nocount on
    
    insert into #database(name)
    
    select name
    
    from sys.databases
    
    where name like '%tgsdb%' --CHANGE HERE THE FILTERING RULE FOR YOUR DATABASES!
    
    and source_database_id is null
    
    order by name
    
    Select *
    from #database
    
    declare @id INT, @cnt INT, @sql NVARCHAR(max), @currentDb sysname;
    
    select @id = 1, @cnt = max(id)
    from #database
    
    while @id <= @cnt
    
    BEGIN
    
            select @currentDb = name
        from #database
        where id = @id
    
        set @sql = 'select Column1, Column2 from ' + @currentDb + '.dbo.Table1'
        print @sql
        exec (@sql);
        print '--------------------------------------------------------------------------'
        set @id = @id + 1;
    
    END
    
    go
    
    0 讨论(0)
  • 2021-02-05 13:53

    I ended up writing one last week on the fly for some stuff I was doing.

    Blog post here:

    http://tsells.wordpress.com/2012/02/14/sql-server-database-iterator/

    Here is the code.

    SET NOCOUNT ON
    GO
    use master
    go
    
    Declare
    @dbname nvarchar(500),
    @variable1 int,
    @variable2 int,
    @variable3 int,
    @totaldb int = 0,
    @totaldbonserver int = 0,
    @totaldbwithmatches int = 0
    
    -- Get non system databases
    Declare mycursor CURSOR for select name, database_id from SYS.databases where database_id > 4 order by name desc
    
    open mycursor
    
    fetch next from mycursor into @dbname, @variable1
    
    while (@@FETCH_STATUS <> -1)
        BEGIN
            DECLARE @ParmDefinition NVARCHAR(500)
            Declare @mysql nvarchar(500) = 'select @variable2OUT = COUNT(*) from [' + @dbname + '].INFORMATION_SCHEMA.TABLES where Upper(TABLE_NAME) like ''MyTable''';
            SET @ParmDefinition = N'@variable2OUT int OUTPUT'
            set @totaldbonserver = @totaldbonserver + 1
            Execute sp_executesql @mysql, @ParmDefinition, @variable2 OUTPUT            
    
            if @variable2 = 1
            BEGIN
                DECLARE @ParmDefinition2 NVARCHAR(500)
                Declare @mysql2 nvarchar(500) = 'select @variable2OUT = COUNT(*) from [' + @dbname + '].dbo.MyTable';
                SET @ParmDefinition2 = N'@variable2OUT int OUTPUT'
                Execute sp_executesql @mysql2, @ParmDefinition2, @variable3 OUTPUT
                set @totaldb = @totaldb + 1
    
                if @variable3 > 1
                BEGIN
                    Print @dbname + ' matched the criteria'
                    set @totaldbwithmatches = @totaldbwithmatches + 1
                END
                ELSE
                Select 1
            END    
    
            fetch next from mycursor into @dbname, @variable1
        END
        PRINT 'Total databases on server: '
        Print @totaldbonserver
    
        PRINT 'Total databases tested () : '
        Print @totaldb
    
        PRINT 'Total databases with matches: '
        Print @totaldbwithmatches
    CLOSE mycursor
    DEALLOCATE mycursor
    
    0 讨论(0)
提交回复
热议问题