T-SQL: Script para hacer copia de seguridad todas las bases de datos en SQL Server

Muchas veces las cosas que parecen complicadas son más fáciles de lo que se cree y esta es una de las ventajas de usar T-SQL para que se encargue de hacer las tareas repetitivas. Una de estas tareas, por ejemplo, puede ser el hacer copias de seguridad de todas las bases de datos en el servidor. A lo mejor si tienes pocas bases de datos es fácil controlarlo, pero evidentemente existen escenarios donde hay más cientos de bases de datos en la misma instancia de SQL Server. Para esto se podría usar SQL Server Management Studio o usar los planes de mantenimiento, pero usar T-SQL es una práctica (en mi caso al menos) mucho más simple y rápida.

Al usar T-SQL se pueden generar loa comandos de Backup en un cursor para luego sacar una copia de todas las bases de datos una por una mediante un bucle. Este es un proceso muy sencillo y sólo necesita unos cuantos comandos para hacer esto.

A continuación muestro el script que permite hacer una copia de seguridad de cada Base de Datos en la instancia de SQL Server.

Importante:  Se tendrá que cambiar el valor del parámetro @path con la ruta deseada.


-- El nombre del fichero tendrá este Formato DB_YYYYDDMM.BAK
DECLARE @name VARCHAR(50) -- Nombre de la Base de Datos  
DECLARE @path VARCHAR(256) -- Ruta para las copias de seguridad
DECLARE @fileName VARCHAR(256) -- Nombre del Fichero
DECLARE @fileDate VARCHAR(20) -- Usado para el nombre del fichero
 
-- Ruta para las copias de seguridad
SET @path = 'd:BackupSQL'  
 
-- Formato del nombre del fichero
SELECT @fileDate = CONVERT(VARCHAR(20),GETDATE(),112) 
 
DECLARE db_cursor CURSOR FOR  
SELECT name 
FROM master.dbo.sysdatabases 
WHERE name NOT IN ('master','model','msdb','tempdb')  -- excluir estas bases datos
 
OPEN db_cursor   
FETCH NEXT FROM db_cursor INTO @name   
 
WHILE @@FETCH_STATUS = 0   
BEGIN   
       SET @fileName = @path + @name + '_' + @fileDate + '.BAK'  
       BACKUP DATABASE @name TO DISK = @fileName  
       FETCH NEXT FROM db_cursor INTO @name   
END   
 
CLOSE db_cursor   
DEALLOCATE db_cursor

 


Notas adicionales:

En este script se omiten las bases de datos del sistema, pero podrían también incluirse. También es posible convertir esto en un procedimiento almacenado y pasarle como parámetro el nombre de la base de datos de la cual se quiere una copia o pasarle NULL si queremos la copia de seguridad de todas las bases de datos.

Sea la forma en la que lo uses,  este script te da un punto de partida para obtener una copia de todas tus bases de datos. Además es posible pasar por alto cualquier base de datos que no se quiera incluir en la copia, agregando su nombre en la sección NOT IN.

Si quieres más trucos de este tipo te invito a echarle un vistazo a este libro de SQL Server 2014 en Español

Comprar en AmazonSQL Server 2014 | Amazon Kindle

15 comentarios

  1. Hola:
    Primero que nada gracias por la aportación, segundo podría poner este script para que corra en el administrador de tareas de windows??, ya que el sql server management studio no lo tengo.

    Desde ya Gracias!!!!

  2. crear un archivo .bat con lo siguiente:

    @set serverffmm=TUservidorSQLServer
    @set bddffmm=master

    osql -E -S %serverffmm% -d %bddffmm% -e -n -m-1 -i scriptdearriba.sql -o salida_Full.log

  3. Gracias por el aporte Mario.

  4. saludes a todos mi consulta es la siguiente como puedo adjuntar datos de una base de datos que están en dos PC que no tengo conectada en red (la Base de Datos es la misma es decir que tengo que importar los datos pero sin que estos me borren, datos de la pc que es mi servidor y me mantengan el historial del registro actualizado ya que esta pasaran luego a las dos pc que no están en red )
    las tablas son las siguiente : la BD ES : Reg_alumnos y sus tablas son: Alumno y Materia

    • Hola, si tus equipos no están en red, definitivamente no puedes implementar ninguna estrategia de replicación. La única forma de tener la misma base de datos en cada equipo es que hagas una copia manual de la base de datos de un ordenador y lo copies al otro, con un pendrive o disco externo.
      Si no vas a restaurar la base de datos completa y solo quieres traspasar una o varias tablas o solo algunos registros, lo puedes hacer con el asistente de scripts (Click derecho a la base de datos | Tareas | Generar Scripts), esto te exportará los datos en scripts que luego puedes ejecutar en el otro ordenador.
      Mi recomendación de todas formas es que veas la forma de conectar los equipos a medida de lo posible, porque estar haciendo eso manualmente, no solo es una perdida de tiempo sino que además siempre tendrás algún desfase de la información y tendrás que estar haciendo revisiones manualmente. Conectar dos equipos en red hoy en día no es costoso.
      Un saludo,

  5. Funciono!!!! mil gracias, era lo que buscaba

  6. Muchassss gracias por la aportacion lo he agregado y funciona a las mil maravillas.

    saludos

  7. una pregunta como seria la sintaxis para que losa respaldos sean con compression?

    Saludos

  8. Esa sería una tarea de un agente aparte. SQL por defecto no comprime. Lo que podrías hacer es crear una tarea con el Administrador de tareas de Windows que periódicamente verifique que si hay ficheros *.BAK en la carpeta los comprima usando winzip/winrar o cualquier otro utilitario de comprensión que te permita ejecutarse mediante línea de comando. Podrías crear un script de tipo BAT o CMD para que se encargue de esa tarea.

  9. hola buenos dias me podrian ayudar porfavor si hubiera un codigo en sql al guardar un backups un codigo para zipiar

    • Juan Carlos Heredia Mayer

      19/04/2016 a las 17:18

      Hola, SQL por defecto no comprime la información. Lo que puedes hacer es un script que automatize la comprensión de ficheros y carpetas. Hay muchas herramientas de terceros que hacen eso, por ejemplo winrar (http://www.rarlab.com/) en modo consola.

  10. Amigo, hola. una consulta….al ejecutar tu script me da error código 5…he hecho de todo, agregue al usuario y los permisos necesarios para la lectura y escritura pero nada…tienes alguna idea de que podría ser ??? saludos amigo y muy buen script.

    • Juan Carlos Heredia Mayer

      25/05/2016 a las 22:42

      Antes de nada, te sugiero probar primero con el usuario SA directamente, recuerda que para sacar copias de seguridad se debe tener los privilegios adecuados.

  11. Hola una consulta. Para que en cada corrida del SQL, se genere automaticamente, la carpeta de destino del backup, eso es posible?
    Por ejemplo en
    — Ruta para las copias de seguridad
    SET @path = ‘d:BackupSQL\20190314’
    y en la proxima ejecución
    SET @path = ‘d:BackupSQL\20190325’
    y así sucesivamente.

    Es posible?
    Gracias!

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

© 2019 Espacio Digital

Tema por Anders NorénSubir ↑