Foros del Web » Programando para Internet » PHP »

sobre los back ups

Estas en el tema de sobre los back ups en el foro de PHP en Foros del Web. tengo quehacer unaaplicación para guardar los datos de una DB de MySQL. estube leyendo en las FAQ's y la verdad no tengo idea donde mi ...
  #1 (permalink)  
Antiguo 15/09/2003, 23:57
Avatar de oktubre  
Fecha de Ingreso: agosto-2003
Ubicación: en mi casa
Mensajes: 371
Antigüedad: 14 años, 3 meses
Puntos: 4
sobre los back ups

tengo quehacer unaaplicación para guardar los datos de una DB de MySQL. estube leyendo en las FAQ's y la verdad no tengo idea donde mi proveedor tiene la ruta al dump...

alguien sabe si puedo generar una consulta que me muestre los datos como lo hace el phpmyadmin?

algo que se pueda compiar y pegar en unblock denotas me sobra.
hace un tiempo lei algo sobre las "vistas de datos", como si estubiera creando unatabla o algo parecido, sirve esto?


gracias.
__________________
[email protected] <----------------<<<<
prefiero cerrar la boca y parecer un tonto que abrirla y confirmarlo.
  #2 (permalink)  
Antiguo 17/09/2003, 18:25
O_O
 
Fecha de Ingreso: enero-2002
Ubicación: Santiago - Chile
Mensajes: 34.417
Antigüedad: 15 años, 11 meses
Puntos: 126
Pues .. si sabes que phpmyadmin "lo hace" .. y sabes que es código PHP "abierto" .. puedes ir empezando por investigar su código para ver cómo lo hacen .. no crees?.

Bueno, te doy algunas guías de cómo lo hace phpmyadmin:

1) .. El objetivo es generar el SQL de INSERT y .. (CREATE TABLE .. si corresponde) de tus consultas SQL para insertar datos (caso de INSERT) o de crear la estructura de tus tablas (caso del CREATE TABLE ..)

2) Todo esto lo puedes generar hacia un archivo .. lo cual implicaría usar funciones de fwrite() fopen() y afines .. o hacia "descargar" .. lo cual implicaría uso de cabeceras HTTP para descarga (header("content-type: ....") y varias más ..)

3) El formato que debes usar paras tus INSERT .. es el que se define en la sintax de uso del SQL de mysql .. Sólo tienes que separar cada bloque "INSERT" por un salto de línea (\n) y un ; (punto y coma) .. Eso le indica a Mysql (SQL) que empieza ahí una nueva instrucción SQL que interpretar ..

4) Generar tus "INSERT" no es más que tratarlo como si de una cadena (string) cualquiera se tratase, pero, con el formato que debes seguir y define su sintax. Así que tendrás que concatenar el valor de tus campos ($row['nose'] ) con el resto de sintax de la isntrucción INSERT (o CREATE TABLE .. si corresponde) con sus , (comas) .. () (parentesis) y ; (punto y coma) .. (recueda el \n como salto de línea).

5) (opcional) .. Si quieres hacerte una aplicación complementaria que sea el de "restaurar" tu back up .. Recuerda que mysql_query() sólo ejecuta una instrucción SQL a la vez. Así que si pretendes leer tu ".SQL" generado para ejecutar el backup "restaurador" .. tendrás que usar explode() para separar instrucciones (al caracter ; ) ...

---------

Con respecto al "dump" .. Si en tu servicio de hosting te dan acceso SHELL (consola) y puedes ejecutar comandos ... NO necesitas conocer la ruta de "dump" ejecutable .. tan sólo usa la sintax correcta (y recuerda en usar rutas absoultas tipo /var/nose .. si es LInux) ...

Anque tengas acceso Shell a tu servicio de hosting .. es probable que no tengas permisos para ejecutar "dump" de mysql .. En tal caso si deseas usarlo visita el manual de Mysql primero, averigüa la sintax de uso (o revisa esa FAQ una vez más) y contacta a tu proveedor de hosting para ver si podrías ejecutarla tu ...

A "malas" tambíen puedes "lanzar" ese tipo de ejecuciones por un exec() o .. system() (entre otras funciones) .. como creo recordar que describe la misma FAQ que vistes (todo esto si corres PHP en modo NO safe mode y tengas permisos de ejecución ..)

Un saludo,
__________________
Por motivos personales ya no puedo estar con Uds. Fue grato haber compartido todos estos años. Igualmente los seguiré leyendo.
  #3 (permalink)  
Antiguo 17/09/2003, 22:06
Avatar de oktubre  
Fecha de Ingreso: agosto-2003
Ubicación: en mi casa
Mensajes: 371
Antigüedad: 14 años, 3 meses
Puntos: 4
gracias, tus respuestas siempre son mas que una guía

veo que tengo mucho trabajo que hacer

saludos
__________________
[email protected] <----------------<<<<
prefiero cerrar la boca y parecer un tonto que abrirla y confirmarlo.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 08:10.