| |||
Backup funciones triggers y procedimientos hola tengo un pequeño problema y esque no se como hacer un backuop correcto de mis bases de datos que contienen funciones triggers y vistas, me explico el buckuo se hace sin problemas pero luego restauracion no funciona tira errores por tos lados y sobre todo no se inserta ninguna funcion trigger o procedimiento las bases de datos son generalmente inno db aver que slucion me dais |
| ||||
Respuesta: Backup funciones triggers y procedimientos Primero deberías se un poco más claro respecto de qué errores son los que tira. Sin indicarnos cuales son los mensajes que se producen, las razones del error pueden ser múltiples, desde diferencia de versiones a errores de sintaxis en los triggers. Pero de todos modos, anticipándome a una posibilidad, debes asegurarte que las funciones donde leas y escribas sobre tablas, contengan antes del BEGIN una línea que diga MODIFIES SQL DATA o bien READS SQL DATA (ver manual de referencia: 19.2.1. CREATE PROCEDURE y CREATE FUNCTION. Hago esta salvedad la hago porque las interfases (consola o MySQL Query Browser) aceptan y ejecutan el código sin estas cláusulas, pero cuando realizar backups la restauración falla. Fíjate si ese es el caso.
__________________ ¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente... "El problema es la interfase silla-teclado." (Gillermo Luque) |
| |||
Respuesta: Backup funciones triggers y procedimientos Hola gracias pro contestar veras el problema que tenemos es que cuando hacemos los backups lo s hacemos de la siguiente forma mysqldump --databases -u xxxxx -p pero el backup que resulta no nos es valido por que cunado inteamos regenerarlo da fallos muchos fallos no sabria decirte cuales esactamente pro que la solucion que hemos adoptado es la de hacerlo por pasos primero sacar las tablas con sus datos y restaurarlo quitando los comentarios que mete mysqldump (#go...etc), entonces queremos saver de que manera o cual es la manera para hacer un correcto backup de una base de datos con tablas innodb y que contienen funciones procedures y triggers. saludos y gracias por tu ayuda. |
| |||
Respuesta: Backup funciones triggers y procedimientos 1. no no la contienen pero hemos echo la prueba y no nos ha funcionado. 2y3.La restauracion la estamos haciendo de un windows 2003 server con mysql 4.1.7 a un linux suse, con mysql 5.0.51a, pero0 hemos probado haciendo el backup y restaurando en la misma maquina y sigue sin funcionar, ¿nos puedes decir como haces el backup?, ¿y la restauración?. |
| ||||
Respuesta: Backup funciones triggers y procedimientos Vamos desde lo básico: 1. La operación que estás tratando de hacer está mal pensada desde el inicio. Lo que tienes que hacer no es una restauración simple de un backup. Lo que estás tratando de hacer es una migración de una base de datos entre versiones no totalmente compatibles. Ten en cuenta que si estás intentando migrar la base desde la versión 4.1 a la 5.0 o superior, siempre hay sentencias y estructuras que cambian. Esas cosas (por ejemplo, los campos ENUM, la definición de las vistas, los tipos de tablas) cambian de una versión a otra. Tanto si lo estás haciendo de la 4 a la 5, como de la 5 a la cuatro, hay elementos incompatibles. 2. Estás cruzando bases de datos entre dos sistemas operativos distintos. En estos casos debes tener en cuenta que Linux, como buen heredero del Unix, diferencia entre mayúsculas y minúsculas, por lo que pueden existir problemas de sintaxis provenientes de allí y que no sean detectables. 3. Los store routines y triggers no existen en MySQL 4.1.7. Jamás se cargarán, por la simple razón de que no los reconoce. No son parte de la versión 4. 4. Si estás intentando realizar un backup desde la versión 5.1 o posterior, puede que no se estén incorporando los SP y SF. Según el manual, el comando debería ser:
Código:
mysqldump -R -h host -u username -p my_db > my_db.sql
__________________ ¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente... "El problema es la interfase silla-teclado." (Gillermo Luque) |