Question : Automated Restoring of SQL Database and transaction logs in SQL 2005

I know very little about SQL 2005 or SQL in general but I do follow instructions very well.  
I have a SQL 2005 Server with a 8GB Database that backs up nightly to a different SQL Server (it just creates a BAK file on the 2nd SQL 2005 drive E). Also the log file gets truncated as well just prior to the backup.
I was hoping to get some simple instructions on restoring the database from SQL 2005 Server 1 (SQL1) to SQL 2005 Server 2 (SQL2) automatically at midnight every day.
What would happen is the data from SQL1 backups and restores to SQL2 every night.
Then every hour send the transaction logs from SQL1 to SQL2 so if something were to happen to SQL1 then we would at most be missing 59mins worth of data.
Is there a simple way to explain it to me?  I do not know many of the terms that SQL uses so please dumb it down as much as you can.
Thank you

Answer : Automated Restoring of SQL Database and transaction logs in SQL 2005

I got this off searchsqlserver, you might not be able to follow the link unless you register for free with them.

http://searchsqlserver.techtarget.com/tip/1,289483,sid87_gci1120213_tax301326,00.html?adg=301324

the best way to automate the restore process is to create a scheduled task, which will be kicked off as needed. The only thing scheduled task change you may need to make is the name of the backup file. For instance, if you are using Maintenance Plans to perform backups, the file name is dynamically created with the database name and datetime the backup started as the file name. A sample script has been included to help you create a scheduled task that does the four items listed above. This is a good way to get all the necessary steps in place to further automate your weekly or daily refreshes of your test or development environments.

Sample script to automate restores

BEGIN TRANSACTION            
  DECLARE @JobID BINARY(16)  
  DECLARE @ReturnCode INT    
  SELECT @ReturnCode = 0    
IF (SELECT COUNT(*) FROM msdb.dbo.syscategories WHERE name = N'[Uncategorized (Local)]') < 1
  EXECUTE msdb.dbo.sp_add_category @name = N'[Uncategorized (Local)]'

  -- Delete the job with the same name (if it exists)

  SELECT @JobID = job_id    
  FROM   msdb.dbo.sysjobs    
  WHERE (name = N'Automated Database Restore')      
  IF (@JobID IS NOT NULL)    
  BEGIN  
  -- Check if the job is a multi-server job  
  IF (EXISTS (SELECT  *
              FROM    msdb.dbo.sysjobservers
              WHERE   (job_id = @JobID) AND (server_id <> 0)))
  BEGIN

    -- There is, so abort the script
    RAISERROR (N'Unable to import job ''Automated Database Restore'' since there is already a
multi-server job with this name.', 16, 1)
    GOTO QuitWithRollback  
  END
  ELSE
    -- Delete the [local] job
    EXECUTE msdb.dbo.sp_delete_job @job_name = N'Automated Database Restore'
    SELECT @JobID = NULL
  END

-- Add the job

  EXECUTE @ReturnCode = msdb.dbo.sp_add_job @job_id = @JobID OUTPUT , @job_name =
N'Automated Database Restore', @owner_login_name = N'sa', @description = N'No description
available.', @category_name = N'[Uncategorized (Local)]', @enabled = 1, @notify_level_email =
0, @notify_level_page = 0, @notify_level_netsend = 0, @notify_level_eventlog = 2,
@delete_level= 0

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  -- Add the job steps

  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID, @step_id = 1,
@step_name = N'Set SINGLE_USER', @command = N'ALTER DATABASE  Northwind SET
SINGLE_USER WITH ROLLBACK IMMEDIATE

', @database_name = N'master', @server = N'', @database_user_name = N'', @subsystem =
N'TSQL', @cmdexec_success_code = 0, @flags = 0, @retry_attempts = 0, @retry_interval = 1,
@output_file_name = N'', @on_success_step_id = 0, @on_success_action = 3,
@on_fail_step_id = 0, @on_fail_action = 2

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID, @step_id = 2,
@step_name = N'Restore Database', @command = N'RESTORE DATABASE Northwind

FROM DISK = ''c:\backup\Northwind.BAK''

WITH MOVE ''Northwind_Data'' TO ''c:\sql\data\Northwind.mdf'',

      MOVE ''Northwind_Log'' TO ''c:\sql\data\Northwind_log.ldf''', @database_name = N'master',
@server = N'', @database_user_name = N'', @subsystem = N'TSQL', @cmdexec_success_code
 = 0, @flags = 0, @retry_attempts = 0, @retry_interval = 1, @output_file_name = N'',
@on_success_step_id = 0, @on_success_action = 3, @on_fail_step_id = 0, @on_fail_action = 2

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID, @step_id = 3,
@step_name = N'Set MULTI_USER', @command = N'ALTER DATABASE Northwind SET
MULTI_USER

', @database_name = N'master', @server = N'', @database_user_name = N'', @subsystem =
N'TSQL', @cmdexec_success_code = 0, @flags = 0, @retry_attempts = 0, @retry_interval = 1,
@output_file_name = N'', @on_success_step_id = 0, @on_success_action = 3,
@on_fail_step_id = 0, @on_fail_action = 2

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID, @step_id = 4,
@step_name = N'Relink users', @command = N'EXEC sp_change_users_login ''Update_One'',
''myuser'', ''myuser''

', @database_name = N'master', @server = N'', @database_user_name = N'', @subsystem =
 N'TSQL', @cmdexec_success_code = 0, @flags = 0, @retry_attempts = 0, @retry_interval = 1,
@output_file_name = N'', @on_success_step_id = 0, @on_success_action = 1,
@on_fail_step_id = 0, @on_fail_action = 2

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  EXECUTE @ReturnCode = msdb.dbo.sp_update_job @job_id = @JobID, @start_step_id = 1

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

  -- Add the Target Servers

  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @JobID, @server_name =
 N'(local)'

  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

END
COMMIT TRANSACTION          
GOTO   EndSave              
QuitWithRollback:
  IF (@@TRANCOUNT > 0) ROLLBACK TRANSACTION
EndSave:

Random Solutions  
 
programming4us programming4us