{"id":15804,"date":"2021-02-25T14:52:21","date_gmt":"2021-02-25T13:52:21","guid":{"rendered":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/"},"modified":"2025-10-01T11:50:31","modified_gmt":"2025-10-01T09:50:31","slug":"sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild","status":"publish","type":"post","link":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/","title":{"rendered":"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild"},"content":{"rendered":"<h3>Introduction<\/h3>\n<p>In this blog post, I will demonstrate how the <a href=\"https:\/\/docs.microsoft.com\/en-us\/sql\/t-sql\/statements\/alter-index-transact-sql?view=sql-server-ver15#online-index-operations\">Resumable<\/a> capability of Online index rebuild operation can help you to keep the transaction log file size under control.<\/p>\n<p>An index rebuild operation is done in a single transaction that can require a significant log space. When doing a Rebuild on a large index the transaction log file can grow until your run out of disk space.<br \/>\nOn failure, the transaction needs to rollback. You end up with a large transaction log file, no free space on your transaction log file volume, and an index not rebuilt.<\/p>\n<p>Since SQL Server 2017 with Enterprise Edition, using the Resumable option of index online rebuild operation we can try to keep under control the transaction log file size.<\/p>\n<h3>Demo<\/h3>\n<p>For the demo, I&#8217;ll use the <a href=\"https:\/\/github.com\/Microsoft\/sql-server-samples\/releases\/tag\/adventureworks\">AdventureWorks<\/a> database with the Adam Machanic&#8217;s <a href=\"https:\/\/web.archive.org\/web\/20130331232013\/http:\/\/sqlblog.com\/blogs\/adam_machanic\/archive\/2011\/10\/17\/thinking-big-adventure.aspx\">bigAdventures<\/a> tables.<\/p>\n<h4>Index rebuild Log usage<\/h4>\n<p>My transaction log file size is 1 GB and it&#8217;s empty.<\/p>\n<div>\n<div id=\"highlighter_472820\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">USE [AdventureWorks2019]<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql plain\">go<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">total_log_size_in_bytes\/1024\/1024 <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">TotalLogSizeMB<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, (total_log_size_in_bytes - used_log_space_in_bytes)\/1024\/1024 <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">FreeSpaceMB<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, used_log_space_in_bytes\/1024.\/1024\u00a0 <\/code><code class=\"sql keyword\">as<\/code> <code class=\"sql plain\">UsedLogSpaceMB,<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">used_log_space_in_percent<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">sys.dm_db_log_space_usage;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>I now rebuild the index on bigTransactionHistory.<\/p>\n<div>\n<div id=\"highlighter_830702\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">ALTER<\/code> <code class=\"sql keyword\">INDEX<\/code> <code class=\"sql plain\">IX_ProductId_TransactionDate <\/code><code class=\"sql keyword\">ON<\/code> <code class=\"sql plain\">bigTransactionHistory REBUILD<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">WITH<\/code> <code class=\"sql plain\">(ONLINE=<\/code><code class=\"sql keyword\">ON<\/code><code class=\"sql plain\">);<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p><a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_2_TXLogUsage_AfterRebuild.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-47811\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_2_TXLogUsage_AfterRebuild.png\" alt=\"\" width=\"609\" height=\"53\" \/><\/a><br \/>\nI had a few autogrowth events bringing my file to 3583 MB. The log space required to rebuild this index is about 3500 MB.<\/p>\n<p>Now, let&#8217;s say I want to limit my transaction log file to 2 GB.<\/p>\n<h4>Index rebuild script<\/h4>\n<p>First, I build a table that contains the list of indexes I have to rebuild during my maintenance window. For the demo purpose it&#8217;s a very simple one:<\/p>\n<div>\n<div id=\"highlighter_538948\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">*<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">IndexToMaintain;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-47812\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_3_IndexToMaintainTabke.png\" alt=\"\" width=\"689\" height=\"48\" \/><\/p>\n<p>The idea is to go through all the indexes to rebuild and start a Rebuild with the option RESUMABLE=ON.<br \/>\nWhen a rebuild is done the value for the RebuildStatus column is updated to 1.<\/p>\n<p>Here is the code:<\/p>\n<div>\n<div id=\"highlighter_627484\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<div class=\"line number16 index15 alt1\">16<\/div>\n<div class=\"line number17 index16 alt2\">17<\/div>\n<div class=\"line number18 index17 alt1\">18<\/div>\n<div class=\"line number19 index18 alt2\">19<\/div>\n<div class=\"line number20 index19 alt1\">20<\/div>\n<div class=\"line number21 index20 alt2\">21<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">WHILE (<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql color2\">Count<\/code><code class=\"sql plain\">(*) <\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">IndexToMaintain <\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">RebuildStatus = 0) &gt; 0<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">BEGIN<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@rebuild <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @DatabaseName <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @TableName <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @IndexName <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @id <\/code><code class=\"sql keyword\">int<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">@DatabaseName = DatabaseName<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @TableName = TableName<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @IndexName = IndexName<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @id = id<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">IndexToMaintain <\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">RebuildStatus = 0;<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">SET<\/code> <code class=\"sql plain\">@rebuild = CONCAT(<\/code><code class=\"sql string\">'ALTER INDEX '<\/code><code class=\"sql plain\">, @IndexName, <\/code><code class=\"sql string\">' ON '<\/code><code class=\"sql plain\">,@DatabaseName, <\/code><code class=\"sql string\">'.dbo.'<\/code><code class=\"sql plain\">, @TableName, <\/code><code class=\"sql string\">' REBUILD WITH (ONLINE=ON, RESUMABLE=ON);'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">exec<\/code><code class=\"sql plain\">(@rebuild)<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">UPDATE<\/code> <code class=\"sql plain\">IndexToMaintain <\/code><code class=\"sql keyword\">SET<\/code> <code class=\"sql plain\">RebuildStatus = 1 <\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">id = @id;<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"sql keyword\">END<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>The commands executed will look like this.<\/p>\n<div>\n<div id=\"highlighter_568344\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">ALTER<\/code> <code class=\"sql keyword\">INDEX<\/code> <code class=\"sql plain\">IX_ProductId_TransactionDate <\/code><code class=\"sql keyword\">ON<\/code> <code class=\"sql plain\">bigTransactionHistory REBUILD<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">WITH<\/code> <code class=\"sql plain\">(ONLINE=<\/code><code class=\"sql keyword\">ON<\/code><code class=\"sql plain\">, RESUMABLE=<\/code><code class=\"sql keyword\">ON<\/code><code class=\"sql plain\">);<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>The Job is scheduled to be run at a &#8220;high&#8221; frequency (depending on the file size) during the defined maintenance window. For example, it could be every 5 minutes between 1am and 3am.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_4_JobSchedule.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-47813\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_4_JobSchedule.png\" alt=\"\" width=\"628\" height=\"131\" \/><\/a><\/p>\n<p>We don&#8217;t need to use ALTER INDEX with RESUME to resume an index rebuild, we can just execute the original ALTER INDEX command again, as found in the DMV. It&#8217;s very useful and simplifies this kind of script.<\/p>\n<h4>Alert on Log Space usage<\/h4>\n<p>To contain the transaction log file size I create an Agent Alert that will be triggered when the file is used at 50%.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_5_LogUsageAlert.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-47814\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_5_LogUsageAlert.png\" alt=\"\" width=\"604\" height=\"322\" \/><\/a>In response to this Alert, it will execute another Job with 2 steps.<\/p>\n<p>The first one checks the DMV index_resumable_operations for any running resumable index operation and pauses it.<\/p>\n<div>\n<div id=\"highlighter_445065\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">IF EXISTS (<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">*<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">AdventureWorks2019.sys.index_resumable_operations<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">state_desc = <\/code><code class=\"sql string\">'RUNNING'<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql keyword\">BEGIN<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@sqlcmd <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)\u00a0\u00a0 <\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">@sqlcmd=CONCAT(<\/code><code class=\"sql string\">'ALTER INDEX '<\/code><code class=\"sql plain\">, iro.<\/code><code class=\"sql keyword\">name<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">' ON '<\/code><code class=\"sql plain\">, OBJECT_NAME(o.object_id), <\/code><code class=\"sql string\">' PAUSE;'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">AdventureWorks2019.sys.index_resumable_operations <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">iro<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql color1\">join<\/code> <code class=\"sql plain\">sys.objects <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">o<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">on<\/code> <code class=\"sql plain\">iro.object_id = o.object_id<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">iro.state_desc = <\/code><code class=\"sql string\">'RUNNING'<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">EXEC<\/code><code class=\"sql plain\">(@sqlcmd)<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"sql keyword\">END<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>The second step will then perform a Log backup to free up the transaction log space inside the file.<\/p>\n<div>\n<div id=\"highlighter_29649\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@backupFile <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000) <\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">SET<\/code> <code class=\"sql plain\">@backupFile = <\/code><code class=\"sql string\">'C:\\Backup\\AdventureWorks2019_'<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">replace<\/code><code class=\"sql plain\">(<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(20),GetDate(),120), <\/code><code class=\"sql string\">':'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'_'<\/code><code class=\"sql plain\">)+<\/code><code class=\"sql string\">'.trn'<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql plain\">BACKUP LOG AdventureWorks2019 <\/code><code class=\"sql keyword\">TO<\/code> <code class=\"sql plain\">DISK = @backupFile<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>The command to be executed by this Job:<\/p>\n<div>\n<div id=\"highlighter_98281\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">ALTER<\/code> <code class=\"sql keyword\">INDEX<\/code> <code class=\"sql plain\">IX_ProductId_TransactionDate <\/code><code class=\"sql keyword\">ON<\/code> <code class=\"sql plain\">bigTransactionHistory PAUSE;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<h3>Running the Rebuild<\/h3>\n<p>I set the RebuildStatus value for my index at 0 and enable the Job (scheduled to run every minute). It starts to run at 13:04.<br \/>\nAs we can see in the Job history the index rebuild job ran twice (around 23s) with a failed status. This means that during rebuild it was stopped by the other job doing a PAUSE followed by a log backup.<br \/>\nThe third time it runs it could finish rebuilding the index, set the RebuildStatus to 1, and quit successfully.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_6_JobHistory_IndexRebuild.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-47818\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_6_JobHistory_IndexRebuild.png\" alt=\"\" width=\"767\" height=\"102\" \/><\/a>The Job triggered by the alert has been run twice.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_7_JobHistory_PauseBackup-1.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-47828\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_7_JobHistory_PauseBackup-1.png\" alt=\"\" width=\"777\" height=\"72\" \/><\/a>Two transaction log backups have been performed.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_9_TXLogBackupFiles.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-47822\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_9_TXLogBackupFiles.png\" alt=\"\" width=\"862\" height=\"65\" \/><\/a>While doing the rebuild we managed to keep the transaction log file at a 2GB size compared to the 3.5GB it would use without using the Resumable feature.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_8_TXLogUsageAfterRebuild.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-47820\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_8_TXLogUsageAfterRebuild.png\" alt=\"\" width=\"603\" height=\"53\" \/><\/a><\/p>\n<h3>Conclusion<\/h3>\n<p>This demo was just an example of how the resumable option of index rebuild could be used to contain the transaction file size during index maintenance.<br \/>\nObviously, this solution is not usable as-is for production. You will find the code on <a href=\"https:\/\/github.com\/relsna\/dba-toolbox\/tree\/main\/Blog\/15%20-%20Resumable%20index%20rebuild%20and%20TXLog\">my GitHub<\/a> if you want to play with it.<br \/>\nI hope you found this blog interesting. Feel free to give me feedback in the comments below.<\/p>\n<p>Written by <a href=\"https:\/\/www.linkedin.com\/in\/steven-naudet-aa540158\/\">Steven Naudet<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Introduction In this blog post, I will demonstrate how the Resumable capability of Online index rebuild operation can help you to keep the transaction log file size under control. An index rebuild operation is done in a single transaction that can require a significant log space. When doing a Rebuild on a large index the [&hellip;]<\/p>\n","protected":false},"author":26,"featured_media":15813,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[229,99],"tags":[2259,2550,533],"type_dbi":[],"class_list":["post-15804","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-database-administration-monitoring","category-sql-server","tag-resumable","tag-sql-server-2","tag-transaction-log"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v27.2 (Yoast SEO v27.2) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild - dbi Blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild\" \/>\n<meta property=\"og:description\" content=\"Introduction In this blog post, I will demonstrate how the Resumable capability of Online index rebuild operation can help you to keep the transaction log file size under control. An index rebuild operation is done in a single transaction that can require a significant log space. When doing a Rebuild on a large index the [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\" \/>\n<meta property=\"og:site_name\" content=\"dbi Blog\" \/>\n<meta property=\"article:published_time\" content=\"2021-02-25T13:52:21+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-10-01T09:50:31+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png\" \/>\n\t<meta property=\"og:image:width\" content=\"602\" \/>\n\t<meta property=\"og:image:height\" content=\"50\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Microsoft Team\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Microsoft Team\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"5 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\"},\"author\":{\"name\":\"Microsoft Team\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4\"},\"headline\":\"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild\",\"datePublished\":\"2021-02-25T13:52:21+00:00\",\"dateModified\":\"2025-10-01T09:50:31+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\"},\"wordCount\":647,\"commentCount\":0,\"image\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png\",\"keywords\":[\"Resumable\",\"SQL Server\",\"transaction log\"],\"articleSection\":[\"Database Administration &amp; Monitoring\",\"SQL Server\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\",\"name\":\"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild - dbi Blog\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png\",\"datePublished\":\"2021-02-25T13:52:21+00:00\",\"dateModified\":\"2025-10-01T09:50:31+00:00\",\"author\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png\",\"contentUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png\",\"width\":602,\"height\":50},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"https:\/\/www.dbi-services.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/\",\"name\":\"dbi Blog\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4\",\"name\":\"Microsoft Team\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g\",\"caption\":\"Microsoft Team\"},\"url\":\"https:\/\/www.dbi-services.com\/blog\/author\/microsoft-team\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild - dbi Blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/","og_locale":"en_US","og_type":"article","og_title":"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild","og_description":"Introduction In this blog post, I will demonstrate how the Resumable capability of Online index rebuild operation can help you to keep the transaction log file size under control. An index rebuild operation is done in a single transaction that can require a significant log space. When doing a Rebuild on a large index the [&hellip;]","og_url":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/","og_site_name":"dbi Blog","article_published_time":"2021-02-25T13:52:21+00:00","article_modified_time":"2025-10-01T09:50:31+00:00","og_image":[{"width":602,"height":50,"url":"http:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png","type":"image\/png"}],"author":"Microsoft Team","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Microsoft Team","Est. reading time":"5 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#article","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/"},"author":{"name":"Microsoft Team","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4"},"headline":"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild","datePublished":"2021-02-25T13:52:21+00:00","dateModified":"2025-10-01T09:50:31+00:00","mainEntityOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/"},"wordCount":647,"commentCount":0,"image":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage"},"thumbnailUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png","keywords":["Resumable","SQL Server","transaction log"],"articleSection":["Database Administration &amp; Monitoring","SQL Server"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/","url":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/","name":"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild - dbi Blog","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage"},"image":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage"},"thumbnailUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png","datePublished":"2021-02-25T13:52:21+00:00","dateModified":"2025-10-01T09:50:31+00:00","author":{"@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4"},"breadcrumb":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#primaryimage","url":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png","contentUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog15_1_TXLogUsage.png","width":602,"height":50},{"@type":"BreadcrumbList","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-control-the-size-of-your-transaction-log-file-with-resumable-index-rebuild\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"https:\/\/www.dbi-services.com\/blog\/"},{"@type":"ListItem","position":2,"name":"SQL Server: Control the size of your Transaction Log file with Resumable Index Rebuild"}]},{"@type":"WebSite","@id":"https:\/\/www.dbi-services.com\/blog\/#website","url":"https:\/\/www.dbi-services.com\/blog\/","name":"dbi Blog","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4","name":"Microsoft Team","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g","caption":"Microsoft Team"},"url":"https:\/\/www.dbi-services.com\/blog\/author\/microsoft-team\/"}]}},"_links":{"self":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/15804","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/users\/26"}],"replies":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/comments?post=15804"}],"version-history":[{"count":2,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/15804\/revisions"}],"predecessor-version":[{"id":40601,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/15804\/revisions\/40601"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media\/15813"}],"wp:attachment":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media?parent=15804"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/categories?post=15804"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/tags?post=15804"},{"taxonomy":"type","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/type_dbi?post=15804"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}