Foros del Web » Programando para Internet » PHP »

Condicionales if en mysql con php

Estas en el tema de Condicionales if en mysql con php en el foro de PHP en Foros del Web. Hola estoy haciendo un proyectito y tengo una duda. Estoy intentando hacer un cron que recorra la base y verifique que los registros que emitidos ...
  #1 (permalink)  
Antiguo 03/01/2010, 15:27
 
Fecha de Ingreso: noviembre-2009
Mensajes: 113
Antigüedad: 14 años, 5 meses
Puntos: 0
Condicionales if en mysql con php

Hola estoy haciendo un proyectito y tengo una duda.
Estoy intentando hacer un cron que recorra la base y verifique que los registros que emitidos a una cierta fecha, al pasar 4 dias, cambien el estado.
E pensado en hacer que cada dia se ejecute una condicion que al llegar a 4, deje de hacerlo y que otra condicion que a todos los que tengan 4, dias le cambie el estado, se me complica aqui porque hay varios, registros con diferentes fechas, otro que pense es usar esto,
Código PHP:
Ver original
  1. // Estable condicion Si el valor es menor nos muestra que no se ejecuta.
  2. <?
  3. if ($int_nodias<="4") {
  4.  
  5. aqui deberia hacer la consulta que incremente dias intimaciones en 1 hasta llegar a cuatro, pero incremente solo los que no han alcansado ese valor, cuando llegue a 4 ya no deberia cambiar.
  6.  
  7.   echo "Los dias no alcanzan."; //puse esto para probar....
  8. }
  9.  
  10. // Si el valor es diferente ejecuta la condicion.
  11.  
  12. else {
  13.  
  14. $sql = "SELECT id FROM infraccion WHERE intimaciones='4'";
  15. $result = mysql_query($sql);
  16. $ids = array();
  17.  
  18. // creamos la lista de los IDs a comparar
  19. while ($row = mysql_fetch_assoc($result)) $ids []= $row['id'];
  20.  
  21. // los usamos finalmente con el operador IN()
  22. $sql = "UPDATE infraccion SET estado = '2-Intimacion' WHERE id IN(" . join(', ', $ids) . ")";  
  23.  
  24.  
  25.  
  26.  
  27.   echo "RegistrosActualizados.";
  28. }
  29. ?>

por otro lado me dijeron que tambien puedo hacer la condicion directamente en el mysql,

Código PHP:
Ver original
  1. //·······obtiene diferencias entre fechas desde el mysql
  2. //SELECT DATEDIFF(fecharesolucion, fechainfraccion) AS diferencia FROM infraccion
  3.  
  4.  
  5.  
  6.  
  7.  
  8. //SELECT to_days(entrega) - to_days(fecha) as diferencia
  9. //FROM trabajos
  10. //WHERE peticion =375
  11. //TO_DAYS(fecha) devuelve la cantidad de días que transcurrieron desde una fecha (creo que desde el 1970-01-01)
  12. //___________

el problema de eso qu eno se como usarla, la fecha actual la tomaria de la variable $fecha que devuelve la fecha actual.

o la ultima que me dijeron es que puedo usar los condicionales IF en mysql que seria muy bueno x que con una sola consulta resuelvo tdo y ahorro codigo.

Quisiera algun concejo x ahi, para guiarme mejor. para resolver este problema
  #2 (permalink)  
Antiguo 04/01/2010, 01:20
Avatar de CdG
CdG
 
Fecha de Ingreso: marzo-2008
Mensajes: 114
Antigüedad: 16 años, 2 meses
Puntos: 2
Respuesta: Condicionales if en mysql con php

Corríjanme si me equivoco, pero lo que intentas hacer son stored procedure. Creo que deberías preguntar aquí.
__________________
no quiero ser un árbol y caminar
Jacinto Piedra
  #3 (permalink)  
Antiguo 04/01/2010, 03:26
 
Fecha de Ingreso: enero-2008
Mensajes: 381
Antigüedad: 16 años, 3 meses
Puntos: 19
Respuesta: Condicionales if en mysql con php

Pero si tiene que poner codigo no puede ir en Bases de datos.
  #4 (permalink)  
Antiguo 04/01/2010, 06:43
 
Fecha de Ingreso: noviembre-2009
Mensajes: 113
Antigüedad: 14 años, 5 meses
Puntos: 0
Respuesta: Condicionales if en mysql con php

no no va con stores.
  #5 (permalink)  
Antiguo 05/01/2010, 09:38
 
Fecha de Ingreso: enero-2010
Mensajes: 127
Antigüedad: 14 años, 4 meses
Puntos: 2
Respuesta: Condicionales if en mysql con php

Eso que tu quieres hacer se hace con un Trigger en mysql buscate que es un trigger en mysql para que veas: el trigger basicamente hace que dependiendo la condicion, borra, agrega o actualiza un campo de la BD, tu le pones que quieres que haga que borre, actualize o agregue en este caso creo q es un UPDATE automatico con el trigger buscalo para que veas...

Etiquetas: condicionales, mysql
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 11:43.