Extraer una DAC de una base de datos
Use el Asistente para extraer aplicación de capa de datos o un script de Windows PowerShell para extraer un paquete de aplicación de capa de datos (DAC) de una base de datos de SQL Server existente. El proceso de extracción crea un archivo de paquete DAC que contiene definiciones de los objetos de base de datos y sus elementos relacionados a nivel de instancia. Por ejemplo, un archivo de paquete DAC contiene las tablas de base de datos, procedimientos almacenados, vistas y usuarios, junto con los inicios de sesión que se asignan a los usuarios de la base de datos.
Antes de empezar: Limitaciones y restricciones, Permisos
Para extraer una DAC, mediante: El Asistente Extraer aplicación de capa de datos, PowerShell
Antes de empezar
Puede extraer una DAC de las bases de datos que residen en instancias de Base de datos SQL o SQL Server 2000 Service Pack 4 o posterior. Si el proceso de extracción se ejecuta en una base de datos que se implementó a partir de una DAC, solo las definiciones de los objetos de la base de datos se extraen. El proceso no hace referencia a la DAC registrada en msdb (master de Base de datos SQL). El proceso de extracción no registra la definición de DAC en la instancia actual del motor de base de datos. Para obtener más información sobre el registro de una DAC, vea Registrar una base de datos como una DAC.
Limitaciones y restricciones
Una DAC se puede extraer solo de una base de datos de Base de datos SQL o SQL Server 2005 Service Pack 4 (SP4) o posterior. No puede extraer ninguna DAC si la base de datos tiene objetos que no se admiten en una DAC o usuarios contenidos. Para obtener más información acerca de los objetos admitidos por una DAC, vea Compatibilidad de DAC con las versiones y objetos de SQL Server.
[Arriba]
Permisos
La extracción de una DAC requiere al menos permisos ALTER ANY LOGIN y VIEW DEFINITION en el ámbito de la base de datos, así como permisos SELECT en sys.sql_expression_dependencies. La extracción de una DAC la pueden realizar los miembros del rol fijo de servidor securityadmin que sean también miembros del rol fijo de base de datos database_owner en la base de datos de la que se extrae la DAC. Los miembros del rol fijo de servidor sysadmin o de la cuenta de administrador del sistema de SQL Server integrada denominada sa también pueden extraer una DAC.
[Arriba]
Usar el Asistente de Extraer aplicación de capa de datos
Para extraer una DAC mediante un asistente
En Explorador de objetos, expanda el nodo de la instancia que contiene la base de datos de la que debe extraerse la DAC.
Expanda el nodo Bases de datos.
Haga clic con el botón secundario en el nodo de la base de datos del cual debe extraerse la DAC, haga clic en Tareas, y seleccione Extraer aplicación de capa de datos...
Complete los cuadros de diálogo del asistente:
Página Introducción
Seleccione Página de datos
Página Definir propiedades
Página Validación y resumen
Página Compilar paquete
[Arriba]
Página Introducción
Esta página describe los pasos para extraer una aplicación de capa de datos.
No volver a mostrar esta página. - Haga clic en la casilla para evitar que la página se muestre en el futuro.
Siguiente >: continúa en la página Elegir método.
Cancelar: termina el asistente sin extraer una aplicación de capa de datos de la base de datos.
[Extraer Asistente]
Seleccione Página de datos
Use esta página del asistente para seleccionar los datos de referencia que desee incluir en el archivo de paquete de la aplicación de capa de datos (DAC). La inclusión de datos en el paquete DAC es opcional. El paquete DAC ya incluirá el esquema de todos los objetos de base de datos compatibles y los objetos de instancia relacionados con la base de datos
Puede incluir hasta 10 MB de datos de referencia en el archivo del paquete DAC. Sin embargo, para las tablas que se vayan a incluir en el DAC, puede que no contengan tipos de datos de objetos binarios grandes (BLOB) como image o varchar(max). Para extraer cantidades de datos más grandes con el fin de transferirlos a otra base de datos, use SQL Server Integration Services, la utilidad de copia masiva o una de las muchas otras técnicas de migración de datos.
Tabla de base de datos: active la casilla situada junto a las tablas de base de datos que contengan los datos que desee incluir en el paquete DAC. Puede seleccionar hasta diez tablas con 10.000 filas o menos.
[Extraer Asistente]
Página Definir propiedades
Use esta página del asistente para describir la aplicación de capa de datos (DAC). Estas propiedades se usan para identificar la DAC y contribuyen a diferenciarla de otras.
Name: este nombre identifica la DAC. Puede ser distinto del nombre del archivo de paquete DAC y debe describir la aplicación. Por ejemplo, si la base de datos se usa para una aplicación de finanzas, puede llamar Finanza a la DAC.
Versión (use xx.xx.xx.xx, donde x es un número): un valor numérico que identifica la versión de la DAC. La versión de DAC se usa en Visual Studio para identificar la versión de la DAC en la que están trabajando los desarrolladores. Al implementar una DAC, la versión se almacena en la base de datos msdb y se puede ver después en el nodo Aplicaciones de capa de datos en SQL Server Management Studio.
Descripción: opcional. Describe la DAC. Al implementar una DAC, la descripción se almacena en la base de datos msdb y se puede ver después en el nodo Aplicaciones de capa de datos en Management Studio.
Guardar en archivo de paquete DAC (incluye extensión .dacpac con nombre de archivo):: guarda la DAC en un archivo de paquete DAC, con una extensión .dacpac. Haga clic en el botón Examinar para especificar el nombre y la ubicación del archivo.
Sobrescribir el archivo existente: seleccione esta casilla para reemplazar el archivo de paquete DAC si ya existe uno con el mismo nombre.
[Extraer Asistente]
Página Validación y resumen
En esta página, el asistente valida que una aplicación de capa de datos (DAC) admite todos los objetos de base de datos. También comprueba las dependencias entre los objetos de base de datos para determinar el conjunto de objetos que se pueden incluir correctamente en la DAC. Tras ello, muestra el informe de validación y resume las opciones que ha seleccionado en este asistente. Para cambiar una opción, haga clic en Anterior. Para empezar a extraer una DAC, haga clic en Siguiente.
[!NOTA]
Si una DAC no admite uno o varios objetos, el botón Siguiente está deshabilitado y el proceso de extracción puede no continuar. En estos casos, se recomienda quitar los objetos no admitidos y volver a ejecutar este asistente.
Resumen: un resumen de las opciones que ha seleccionado aparecen en propiedades de DAC. Los resultados de la validación se enumeran en Objetos de DAC. La validación produce tres tipos de resultados:
Objetos admitidos en una DAC: se admiten estos objetos y sus dependencias y se pueden incluir correctamente en la DAC.
Objetos admitidos en una DAC con advertencias: se admiten estos objetos, pero dependen de otros objetos que no se admiten en una DAC.
Objetos no admitidos en una DAC: estos objetos no se admiten y se deben quitar de la base de datos antes de extraer una DAC correctamente.
El proceso de validación comprueba varios niveles de dependencias. Por ejemplo, si un procedimiento almacenado depende de una tabla que usa un tipo de datos CLR no admitido, el procedimiento almacenado se enumerará en Objetos incluidos en DAC con advertencias.
Si una DAC no admite uno o varios objetos, el botón Siguiente está deshabilitado y el proceso de extracción no continuará. En estos casos, se recomienda quitar los objetos que no están admitidos y volver a ejecutar este asistente.
Guardar informe: permite guardar un archivo basado en HTML que enumera todos los objetos del nodo Objetos DAC en el resumen. Este informe puede ser útil cuando algunos de objetos de base de datos no se admiten en una DAC. Use el informe para cambiar o quitar objetos que no se admiten, antes de intentar extraer la DAC de nuevo.
[Extraer Asistente]
Página Compilar paquete
Use esta página para supervisar el progreso del asistente cuando extrae la aplicación de capa de datos (DAC).
Acción: durante la acción Crear y guardar archivo de paquete DAC, el asistente extrae una DAC de la base de datos de SQL Server. A continuación, se crea un paquete DAC en memoria y se guarda en la ubicación especificada. Haga clic en los vínculos de la columna Resultado para ver el resultado del paso correspondiente.
Guardar informe: haga clic en esta opción para guardar los resultados del progreso del asistente en un archivo.
Terminar: haga clic en esta opción para cerrar el asistente después de que se haya completado el procesamiento, o si se produce un error.
[Extraer Asistente]
Extraer una DAC con PowerShell
Para extraer una DAC de una base de datos mediante el método de Extract() en un script de PowerShell
Cree un objeto SMO Server y establézcalo en la instancia que contiene la base de datos desde la que se va a extraer una DAC.
Agregue una variable que especifique el nombre de la base de datos.
Especifique los metadatos de la DAC, como su nombre, versión y descripción.
Especifique la ruta de acceso y el nombre de archivo para el archivo de paquete DAC extraído.
Ejecutar el método Extract con la información especificada anteriormente.
[Arriba]
Ejemplo (PowerShell)
En el siguiente ejemplo se extrae una DAC denominada MyApplication de una base de datos llamada MyDB.
## Set a SMO Server object to the default instance on the local computer.
CD SQLSERVER:\SQL\localhost\DEFAULT
$srv = get-item .
## Specify the database to extract to a DAC.
$dbname = "MyDB"
## Specify the DAC metadata.
$applicationname = "MyApplication"
$version = "1.0.0.0"
$description = "This DAC defines the database used by my application."
## Specify the location and name for the extracted DAC package.
$dacpacPath = "C:\MyDACs\MyApplication.dacpac"
## Extract the DAC.
$extractionunit = New-Object Microsoft.SqlServer.Management.Dac.DacExtractionUnit($srv, $dbname, $applicationname, $version)
$extractionunit.Description = $description
$extractionunit.Extract($dacpacPath)
[Arriba]