Restore - too recent to apply to the database?

  • That's not what I meant. All I can see is a 'domain unregistered' error image.

    Edit your post. Go to the section below the edit box. Click Edit Attachements. Click Browse. Find the image file (on your PC). Click Open. Click Upload.

    No shrink will not be causing this. You should, however, not be shrinking your database on a regular basis. It's incredibly bad practice.

    Gail Shaw
    Microsoft Certified Master: SQL Server, MVP, M.Sc (Comp Sci)
    SQL In The Wild: Discussions on DB performance with occasional diversions into recoverability

    We walk in the dark places no others will enter
    We stand on the bridge and no one may pass
  • here it is... sorry : the image was showing fine on my computer so i thought everybody could see it

  • Lots wrong with that maint plan, but nothing that should be causing this.

    You don't need to rebuild and reorganise indexes. Rebuild does everything reorg does and more. Pick one, drop the other. Better yet, go hunt the net for an index rebuild script (try http://www.sqlfool.com) that only rebuilds what needs rebuilding and doesn't do everything.

    The shrink right after the index rebuild is undoing everything that the rebuild did. Shrink causes massive fragmentation and you'll probably have higher fragmentation after running that than you did before rebuilding indexes. Lose that step, you should not be shrinking the DB on a regular basis.

    Are you sure there's no other log backup job?

    Check the sQL error log, all backups are logged, check that there are no unexpected logs. Query the msdb backup tables and check the same.

    Gail Shaw
    Microsoft Certified Master: SQL Server, MVP, M.Sc (Comp Sci)
    SQL In The Wild: Discussions on DB performance with occasional diversions into recoverability

    We walk in the dark places no others will enter
    We stand on the bridge and no one may pass
  • no this is the only bakcup FULL that is performed, the one from the maintenance plan.

    it used to work fine since many month but now i am getting this issue : i can rebuild the transaction log shipping but it only last for a day... after the full bakcup, it starts to fail again. I have done it three times already and same issue.

  • This won't help with the Restore issue you're experiencing but to aid what Gail mentioned, you could use it to replace those rebuild/reorg steps in your Maintenance plan

    You can use the dba_ReBuildOrReorgIndexesByFragLevel for each database individually (and leave it at that) or you can use the second procedure to execute the first procedure automagically for all databases on your SQL server. Not sure the critique Gail may have with this script 😉 but it's been working very well for our organization since I implemented it a couple weeks back

    USE [F1Settings]

    GO

    /****** Object: StoredProcedure [dbo].[dba_ExecuteServerIndexMaintenance] Script Date: 03/22/2011 14:44:15 ******/

    IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[dba_ExecuteServerIndexMaintenance]') AND type in (N'P', N'PC'))

    DROP PROCEDURE [dbo].[dba_ExecuteServerIndexMaintenance]

    GO

    USE [F1Settings]

    GO

    /****** Object: StoredProcedure [dbo].[dba_ExecuteServerIndexMaintenance] Script Date: 03/22/2011 14:44:15 ******/

    SET ANSI_NULLS ON

    GO

    SET QUOTED_IDENTIFIER ON

    GO

    /* ############################################################################################################### */

    --EXECUTE SERVER INDEX MAINTENANCE

    /* ############################################################################################################### */

    CREATE PROCEDURE [dbo].[dba_ExecuteServerIndexMaintenance](

    @FillFactor varchar(2),

    @MinPages varchar(2) = '50',

    @Exec varchar(1)

    )

    AS

    /*

    ----------------------------------------------------------------------------------------------------------------

    Purpose:Executes F1Settings.dbo.dba_ReBuildOrReorgIndexesByFragLevel to run against ALL DB's on the

    EXECUTING SERVER; excluding master, tempdb, model, msdb, and distribution

    Department:DBA

    Created For:John Doe

    ----------------------------------------------------------------------------------------------------------------

    NOTES:1)Passes in parameters to the primary stored-procedure

    ----------------------------------------------------------------------------------------------------------------

    Created On:03/15/2011

    Create By:MyDoggieJessie

    ----------------------------------------------------------------------------------------------------------------

    Modified On:

    Modified By:

    Changes:

    1.

    ----------------------------------------------------------------------------------------------------------------

    exec dbo.dba_ExecuteServerIndexMaintenance '92', 2, 0

    */

    SET NOCOUNT ON

    DECLARE @iint

    DECLARE @Recsint

    DECLARE @Tablesysname

    DECLARE @sqlnvarchar(500)

    /* ######################################### START MAIN PROCEDURE HERE ########################################## */

    /* Create Temp Table to store the results in */

    CREATE TABLE #Results (

    Idx int IDENTITY(1,1), TName sysname

    )

    /* Fetch All the DB's on the Server */

    INSERT INTO #Results

    EXEC sp_MSForEachDB 'Use [?]; SELECT DB_NAME()'

    /* Get rid of the ones we don't want to index */

    DELETE FROM #Results

    WHERE TName IN ('MASTER', 'TEMPDB', 'MODEL', 'MSDB', 'DISTRIBUTION', 'AdventureWorks')

    /* Loop through the DB's and kick off the magic */

    SET @recs = (SELECT COUNT(1) FROM #Results)

    WHILE @Recs <> 0

    BEGIN

    SET @TABLE = (SELECT Top 1 TName FROM #Results )

    SET @sql = ' exec F1Settings.dbo.dba_ReBuildOrReorgIndexesByFragLevel '''

    + @Table + ''', ''' + @FillFactor + ''', ' + @MinPages + ', ' + @Exec

    EXEC sp_executesql @sql

    DELETE FROM #Results WHERE TName = @Table

    SET @recs = (SELECT COUNT(1) FROM #Results)

    END

    /* ########################################## END MAIN PROCEDURE HERE ########################################### */

    DROP TABLE #Results

    /*

    exec dbo.dba_ExecuteServerIndexMaintenance '92', 2, 0

    */

    SET NOCOUNT OFF

    GO

    USE [F1Settings]

    GO

    /****** Object: StoredProcedure [dbo].[dba_ReBuildOrReorgIndexesByFragLevel] Script Date: 03/22/2011 14:43:55 ******/

    IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[dba_ReBuildOrReorgIndexesByFragLevel]') AND type in (N'P', N'PC'))

    DROP PROCEDURE [dbo].[dba_ReBuildOrReorgIndexesByFragLevel]

    GO

    USE [F1Settings]

    GO

    /****** Object: StoredProcedure [dbo].[dba_ReBuildOrReorgIndexesByFragLevel] Script Date: 03/22/2011 14:43:55 ******/

    SET ANSI_NULLS ON

    GO

    SET QUOTED_IDENTIFIER ON

    GO

    /* ############################################################################################################### */

    --DYNAMICALLY REORG/REBUILD SERVER INDEXES BY FRAGMENTATION LEVEL

    /* ############################################################################################################### */

    CREATE PROCEDURE [dbo].[dba_ReBuildOrReorgIndexesByFragLevel] (

    @DB varchar(50),

    @FillFactor varchar(2),

    @MinPages int = 50,

    @Exec int

    )

    AS

    /*

    ----------------------------------------------------------------------------------------------------------------

    Purpose:Written to dynamically perform maintenance on indexes if fragmentation gets too high

    Department:DBA

    Created For:John Doe----------------------------------------------------------------------------------------------------------------

    NOTES:* Primary concept originally created by Microsoft *

    * Error corrected by Pinal Dave (http://www.SQLAuthority.com) *

    ----------------------------------------------------------------------------------------------------------------

    Created On:03/14/2011

    Create By:MyDoggieJessie----------------------------------------------------------------------------------------------------------------

    Modified On:03/18/2011

    Modified By:MyDoggieJessie

    Changes:

    1.Changed datatypes from varchar to sysname for TName, @tablename, and @IdxName

    ----------------------------------------------------------------------------------------------------------------

    exec dbo.dba_ReBuildOrReorgIndexesByFragLevel 'AdventureWorks', '92', 2, 0

    */

    SET NOCOUNT ON

    IF OBJECT_ID ('tempdb.dbo.#fraglist','u') IS NOT NULL

    BEGIN

    DROP TABLE #fraglist

    END

    IF OBJECT_ID ('tempdb.dbo.#tables','u') IS NOT NULL

    BEGIN

    DROP TABLE #tables

    END

    -- Declare variables

    DECLARE @TableNamesysname,@sqlvarchar(1500)

    DECLARE @objectidint,@XTypevarchar(3)

    DECLARE @indexidint,@fragdecimal

    DECLARE @IdxNamesysname,@Recsint

    DECLARE @Errvarchar(500),@iint

    DECLARE @Versionvarchar(3),@Schemavarchar(3)

    DECLARE @Threshold1decimal,@Threshold2decimal

    SET @i = 1

    SET @Version = UPPER(CONVERT(varchar(3), SERVERPROPERTY('edition')))

    /* ######################################### START MAIN PROCEDURE HERE ########################################## */

    CREATE TABLE #Tables (

    Idx int IDENTITY(1,1),

    TName sysname,

    TType varchar(3),

    SSchema varchar(3)

    )

    SET @sql = '

    SELECT CAST(TABLE_NAME AS VARCHAR(100)) AS Table_Name, ''ON'' AS Table_Type, TABLE_SCHEMA

    FROM ' + RTRIM(@DB) + '.INFORMATION_SCHEMA.TABLES

    WHERE TABLE_TYPE = ''BASE TABLE''

    AND [table_name] NOT IN (

    SELECT DISTINCT a.name

    FROM ' + RTRIM(@DB) + '.sys.sysobjects AS a WITH(READUNCOMMITTED)

    JOIN ' + RTRIM(@DB) + '.sys.syscolumns AS b WITH(READUNCOMMITTED) ON

    a.id=b.id

    JOIN ' + RTRIM(@DB) + '.sys.syscolumns AS c WITH(READUNCOMMITTED) ON

    c.xtype=b.xtype

    WHERE b.xType IN (''34'',''35'',''99'',''241''))

    AND TABLE_NAME NOT LIKE ''MS%''

    UNION

    SELECT CAST(TABLE_NAME AS VARCHAR(100)) AS Table_Name, ''OFF'' AS Table_Type, TABLE_SCHEMA

    FROM ' + RTRIM(@DB) + '.INFORMATION_SCHEMA.TABLES

    WHERE TABLE_TYPE = ''BASE TABLE''

    AND [table_name] IN (

    SELECT DISTINCT a.name

    FROM ' + RTRIM(@DB) + '.sys.sysobjects AS a WITH(READUNCOMMITTED)

    JOIN ' + RTRIM(@DB) + '.sys.syscolumns AS b WITH(READUNCOMMITTED) ON

    a.id=b.id

    JOIN ' + RTRIM(@DB) + '.sys.syscolumns AS c WITH(READUNCOMMITTED) ON

    c.xtype=b.xtype

    WHERE b.xType IN (''34'',''35'',''99'',''241''))

    AND TABLE_NAME NOT LIKE ''MS%''

    ORDER BY TABLE_NAME;'

    INSERT INTO #Tables

    EXEC(@SQL)

    -- Create the temporary table.

    CREATE TABLE #fraglist (

    ObjectName sysname,ObjectId int,IndexName sysname,

    IndexId int,Lvl int,CountPages int,

    CountRows int,MinRecSize int,MaxRecSize int,

    AvgRecSize int,ForRecCount int,Extents int,

    ExtentSwitches int,AvgFreeBytes int,AvgPageDensity int,

    ScanDensity decimal,BestCount int,ActualCount int,

    LogicalFrag decimal,ExtentFrag decimal

    )

    SET @Recs = (SELECT COUNT(1) FROM #Tables)

    WHILE @i <= @Recs

    BEGIN

    SET @TableName = (SELECT TOP 1 TName FROM #Tables WHERE Idx = @i)

    SET @Schema = (SELECT TOP 1 SSchema FROM #Tables WHERE Idx = @i)

    -- Do the showcontig of all indexes of the table

    INSERT INTO #fraglist

    EXEC ('DBCC SHOWCONTIG (''' + @DB + '.' + @Schema + '.[' + @TableName + ']'')

    WITH FAST, TABLERESULTS, ALL_INDEXES, NO_INFOMSGS')

    SET @i = @i + 1

    END

    /* Add column needed so we can perform ON/OFFLINE statements */

    ALTER TABLE #fraglist

    ADD idxType varchar(3) NULL

    IF RTRIM(@Version) = 'STA'

    BEGIN

    UPDATE #fraglist

    SET idxType = 'OFF' FROM #Tables WHERE ObjectName = TName

    END

    ELSE

    BEGIN

    UPDATE #fraglist

    SET idxType = TType FROM #Tables WHERE ObjectName = TName

    END

    /* Remove records not needed for the Cursor */

    DELETE FROM #fraglist

    WHERE CountPages < @MinPages

    -- Declare the cursor for the list of indexes to be defragged.

    DECLARE indexes CURSOR FOR

    SELECT

    ObjectName, ObjectId, IndexId, LogicalFrag, IndexName,

    CASE WHEN INDEXPROPERTY (ObjectId, IndexName, 'IndexDepth') IS NULL THEN 'OFF'

    ELSE idxType END

    FROM #fraglist

    WHERE

    CountPages > @MinPages --LogicalFrag >= @MaxFrag

    AND ISNULL(INDEXPROPERTY (ObjectId, IndexName, 'IndexDepth'), 1) > 0

    ORDER BY LogicalFrag DESC

    -- Open the cursor.

    OPEN indexes

    -- Loop through the indexes.

    FETCH NEXT

    FROM indexes

    INTO @TableName, @objectid, @indexid, @frag, @IdxName, @XType

    SET @i = 0

    WHILE @@FETCH_STATUS = 0

    BEGIN

    IF (@Exec = 0)

    BEGIN

    SET @i = @i + 1

    IF @frag BETWEEN 13 AND 20

    BEGIN

    PRINT RTRIM(CONVERT(varchar(10),@i))+'. [' + RTRIM(CONVERT(VARCHAR(15),@frag)) + '%] '

    + RTRIM(@IdxName) + ' - ALTER INDEX [' + RTRIM(@IdxName) + '] ON '

    + RTRIM(@DB) + '.' + @Schema + '.[' + RTRIM(@TableName) + ']'

    + ' REORGANIZE WITH ( LOB_COMPACTION = ON )'

    END

    IF @frag > 20

    BEGIN

    PRINT RTRIM(CONVERT(varchar(10),@i))+'. [' + RTRIM(CONVERT(VARCHAR(15),@frag)) + '%] '

    + RTRIM(@IdxName) + ' - ALTER INDEX [' + RTRIM(@IdxName) + '] ON '

    + RTRIM(@DB) + '.' + @Schema + '.[' + RTRIM(@TableName) + ']'

    + ' REBUILD WITH ( SORT_IN_TEMPDB = OFF, FILLFACTOR = '

    + @FillFactor + ', MAXDOP = 0 , ONLINE = ' + @XType + ' ) '

    END

    END

    ELSE

    BEGIN

    SET @i = @i + 1

    IF @frag BETWEEN 13 AND 20

    BEGIN

    SELECT @sql = 'ALTER INDEX [' + RTRIM(@IdxName) + '] ON '

    + RTRIM(@DB) + '.' + @Schema + '.[' + RTRIM(@TableName) + ']'

    + ' REORGANIZE WITH ( LOB_COMPACTION = ON )'

    BEGIN TRY

    PRINT(@SQL)

    EXEC (@SQL)

    END TRY

    BEGIN CATCH

    PRINT ('ERROR FOUND: ' + ERROR_MESSAGE())

    END CATCH

    END

    IF @frag > 20 --> Rebuild Indexes

    BEGIN

    SELECT @sql = 'ALTER INDEX [' + RTRIM(@IdxName) + '] ON '

    + RTRIM(@DB) + '.' + @Schema + '.[' + RTRIM(@TableName) + ']'

    + ' REBUILD WITH ( SORT_IN_TEMPDB = OFF, FILLFACTOR = '

    + @FillFactor + ', MAXDOP = 0 , ONLINE = ' + @XType + ' ) '

    BEGIN TRY

    PRINT(@SQL)

    EXEC (@SQL)

    END TRY

    BEGIN CATCH

    PRINT ('ERROR FOUND: ' + ERROR_MESSAGE())

    END CATCH

    END

    END

    FETCH NEXT

    FROM indexes

    INTO @TableName, @objectid, @indexid, @frag, @IdxName, @XType

    END

    -- Close and deallocate the cursor.

    CLOSE indexes

    DEALLOCATE indexes

    /* ########################################## END MAIN PROCEDURE HERE ########################################### */

    /*

    exec dbo.dba_ReBuildOrReorgIndexesByFragLevel 'CORELIBRARY_STAGING', '96',50, 0

    */

    -- Delete the temporary table.

    DROP TABLE #fraglist

    DROP TABLE #Tables

    GO

    ______________________________________________________________________________Never argue with an idiot; Theyll drag you down to their level and beat you with experience

  • djguana (3/25/2011)


    no this is the only bakcup FULL that is performed, the one from the maintenance plan.

    Not asking about full backups. Full backups don't break log shipping.

    Can you check the logs and the msdb tables and make sure that no LOG backups are running at the same time as the full, no log backups other than what the log shipping runs.

    Gail Shaw
    Microsoft Certified Master: SQL Server, MVP, M.Sc (Comp Sci)
    SQL In The Wild: Discussions on DB performance with occasional diversions into recoverability

    We walk in the dark places no others will enter
    We stand on the bridge and no one may pass
  • Any idea for the reason why the transaction log shipping is out of sync after my maintenance plan ?

  • djguana (3/25/2011)


    Any idea for the reason why the transaction log shipping is out of sync after my maintenance plan ?

    Somewhere other than the log shipping you have a scheduled job that is performing a Transaction Log backup. That job/task/application/whatever needs to be stopped.

    If you're shipping logs, you should not be doing any other t-log backups anywhere for the database(s) you are shipping.

    Have you recently installed a backup agent such as avamar, veritas, or another client for backups?

    Avamar calls a transaction log backup an incremental backup in its agent configuration, and that would need to be stopped. If you temporarily disable log shipping, do you still see transaction log backups in the SQL error log on the server? As stated above, they are coming from somewhere, but fortunately they are logged.



    --Mark Tassin
    MCITP - SQL Server DBA
    Proud member of the Anti-RBAR alliance.
    For help with Performance click this link[/url]
    For tips on how to post your problems[/url]

Viewing 8 posts - 31 through 37 (of 37 total)

You must be logged in to reply to this topic. Login to reply