Tengo varios clientes con SQL Server 2008 y eso es lo que tengo aquí también en mi servidor. Utilizo archivos de respaldo para enviar bases de datos entre clientes y en mi oficina.
He leído que cuando crea una copia de seguridad desde SQL Server 2012 no hay forma de restaurarla en una instancia de 2008. Supuse que el nivel de compatibilidad solucionaría este problema, pero no lo hace. Por lo tanto, no sé cómo actualizar. Aparte de actualizar todos mis clientes a la vez, lo cual es imposible, no se me ocurre ninguna forma limpia de hacerlo.
Tengo la necesidad de enviar una base de datos a un cliente, así como recibir una base de datos de un cliente. Esta es mi primera actualización de versión en SQL Server, así que soy nuevo en este problema. Alguna idea de cómo proceder?
fuente
Respuestas:
Aquí hay dos cosas involucradas: el número de versión del archivo y el nivel de compatibilidad. Cuando adjunta una base de datos a una versión principal más nueva (como de 2008 a 2008R2 o 2008R2 a 2012), la versión de la base de datos cambia permanentemente y no puede volver a adjuntar esa base de datos a una versión anterior.
El nivel de compatibilidad es para analizar T-SQL obsoleto de la vieja escuela que solía funcionar en versiones anteriores de SQL Server. No cambia cómo se almacenan los datos en el disco.
Para entregar la base de datos a alguien en una versión anterior de SQL Server, deberá exportar los datos e importarlos a otra base de datos. Herramientas como la Comparación de datos de Red Gate son útiles para esto.
fuente
bcp
.SQL Server utiliza la configuración del nivel de compatibilidad para determinar cómo se deben manejar ciertas características nuevas. De esta forma, una base de datos podría migrarse a una versión más nueva de SQL sin tener problemas con la aplicación. El nivel de compatibilidad se puede cambiar de un lado a otro.
Desafortunadamente, los archivos de respaldo no son compatibles con versiones anteriores. Un método sería usar la importación / exportación para mover sus datos de su base de datos actual a su instancia de versión anterior.
fuente
Para las migraciones de SQL, use el Asistente de migración de bases de datos SQL gratuito y de código abierto.
Tenía una base de datos de 5GB con un par de ~ 10 millones de registros e intenté la ruta a través de Generate Script y luego la ejecuté con sqlcmd.exe. En primer lugar, el script generado no siempre funcionaba correctamente. En segundo lugar, sqlcmd.exe también puede fallar en archivos grandes, quejándose de la memoria disponible. osql.exe funciona, pero solo lleva años (y tiene los mismos argumentos de línea de comandos).
Luego encontré una herramienta maravillosa para migrar SQL Server a bases de datos SQL Azure. Esto también funciona para SQL Server a SQL Server, por ejemplo, si desea migrar una base de datos SQL 2012 a 2008 R2. Utiliza bcp.exe, que usa copia masiva. Hay una versión de GUI y línea de comandos (Batch) disponible y es de código abierto. Ver http://sqlazuremw.codeplex.com/ . En mi caso, la operación tomó 16 minutos.
En una pantalla avanzada, puede seleccionar que su objetivo sea SQL Server, no SQL Azure.
fuente
He encontrado que BCP es más efectivo que algunas de las herramientas para obtener datos en una versión anterior de SQL Server y para extraer datos de RDS. (Gracias @ivan_posdeev.)
Primero genero el esquema haciendo clic derecho en la base de datos en SQL Server Management Studio, Tareas, Generar scripts. Marque todos los objetos, en los objetos avanzados, asegúrese de que todo lo que necesita se guionará (estadísticas, índices, etc.), desmarque "USAR base de datos" si su base de datos de destino tiene un nombre diferente, configure la compatibilidad con la versión de su base de datos de destino y genere un archivo que crea su esquema. Cree una base de datos en su destino y ejecute este archivo en ella (usando
osql
,sqlcmd
o la GUI).Para mover los datos, ejecute la siguiente consulta dos veces en la base de datos de origen , primero comentando la segunda columna para generar el archivo por lotes para extraer datos, luego comentando la primera columna para generar el archivo por lotes de importación para ejecutar en su destino. (Debe agregar sus servidores de origen y destino, nombres de instancia, directorios de archivos de salida y entrada, nombres de usuario y contraseñas. Para usar la seguridad integrada, reemplace las opciones
-U
y-P
con solo-T
).Esto es compatible con Unicode, si no lo necesita, cambie el
-N
interruptor en ambas declaraciones a-n
.Después de ejecutar, compruebe los archivos llamados schema.tablename.ERRORS.dat: incluirá las filas que fallaron, vacías si no lo hizo.
Referencia de MSDN para BCP aquí , recorrido más amigable de las opciones de BCP aquí .
He encontrado esto muy superior a la generación de scripts, y cualquiera de las herramientas que he probado. También se ejecuta en bases de datos RDS (que no permiten copias de seguridad). Los archivos de datos generados tienen un 30% del tamaño de los scripts SQL, su ejecución lleva una fracción del tiempo y es mucho más confiable. (Las secuencias de comandos generadas por SQL Server para los datos de secuencias de comandos siempre se dispararon, a veces de manera predecible a veces no, el SQL generado no era compatible con 2008R2 (por ejemplo, usado
nvarchar(0)
, a menudo no se completó sin razón aparente, etc. BCP también replica cualquier violación de restricciones , como la integridad referencial).fuente