Foros del Web » Programando para Internet » PHP »

no me funcionan estos update

Estas en el tema de no me funcionan estos update en el foro de PHP en Foros del Web. Hola este es mi codigo de parte de una mantenedor y solo me hace el primer update y los otros no ¿porque sera?. Datos: todas ...
  #1 (permalink)  
Antiguo 30/06/2010, 09:47
 
Fecha de Ingreso: julio-2009
Mensajes: 29
Antigüedad: 14 años, 8 meses
Puntos: 0
no me funcionan estos update

Hola este es mi codigo de parte de una mantenedor y solo me hace el primer update y los otros no ¿porque sera?.

Datos: todas las variables entran como true, por si sola me funcionan pero necesito hacer que me discrimine ya que en algunas ocaciones solo se modificaran 1 o 2 o los 3. De ante mano muchas gracias.

if (titulo_modificado == true)
{
$sql = "UPDATE `productos` SET ";
$sql .= "titulo = '".$titulo."' " ;
$sql .= "WHERE id = '$id_registro' LIMIT 1";
}
elseif (imagen_modificado == true)
{
$sql = "UPDATE `productos` SET ";
$sql .= "url_imagen = '".$nombre_archivo."' " ;
$sql .= "WHERE id = '$id_registro' LIMIT 1";
}
elseif (categoria_modificado == true)
{
$sql = "UPDATE `productos` SET ";
$sql .= " id_categoria = '".$id_categoria."', " ;
$sql .= "WHERE id = '$id_registro' LIMIT 1";
}
  #2 (permalink)  
Antiguo 30/06/2010, 09:52
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: no me funcionan estos update

No te falta el símbolo de $ en tus variables???

Saludos.
  #3 (permalink)  
Antiguo 30/06/2010, 09:55
Avatar de venom_mau  
Fecha de Ingreso: julio-2009
Mensajes: 152
Antigüedad: 14 años, 9 meses
Puntos: 2
Respuesta: no me funcionan estos update

Te recomiendo usar las etiquetas de ([HTML], [PHP], etc.) para que se vea bien tu código.

Quizá estés usando mal las comillas:
Código PHP:
if (titulo_modificado == true)
{
$sql "UPDATE `productos` SET ";
$sql .= "titulo = '".$titulo."' " ;
$sql .= "WHERE id = '$id_registro' LIMIT 1";
}
elseif (
imagen_modificado == true)
{
$sql "UPDATE `productos` SET ";
$sql .= "url_imagen = '".$nombre_archivo."' " ;
$sql .= "WHERE id = '$id_registro' LIMIT 1";
}
elseif (
categoria_modificado == true)
{
$sql "UPDATE `productos` SET ";
$sql .= " id_categoria = '".$id_categoria."', " ;
$sql .= "WHERE id = '$id_registro' LIMIT 1";

Al concatenar "titulo = '".$titulo."'"; puede estar fallando, prueba:
Código PHP:
if (titulo_modificado == true)
{
$sql "UPDATE `productos` SET ";
$sql .= "titulo = ".$titulo.' ;
$sql .= "WHERE id = '
$id_registro LIMIT 1";

Debes penasr en esas concatenaciones como unas llaves ({}), donde abre una, debe cerrar otra para que puedas concatenar una variable.
Espero te ayude y no te confunda más :P
  #4 (permalink)  
Antiguo 30/06/2010, 10:10
 
Fecha de Ingreso: julio-2009
Mensajes: 29
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: no me funcionan estos update

GatorV, el error no pasa por eso ya que php lee de igual manera esa variable .

vemon_mau, no creo que sea asi gracias de todas maneras.
  #5 (permalink)  
Antiguo 30/06/2010, 10:19
Avatar de quike88  
Fecha de Ingreso: agosto-2008
Mensajes: 471
Antigüedad: 15 años, 7 meses
Puntos: 87
Respuesta: no me funcionan estos update

su usas if.... elseif y entra al 1ro, obviamente no te hará nada que este en el else.

Deberías utilizar solo if en los 3 casos, para que así de acuerdo al valor de las variables, entre a 1, 2 o los 3.

Saludos.
  #6 (permalink)  
Antiguo 30/06/2010, 10:23
 
Fecha de Ingreso: julio-2009
Mensajes: 29
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: no me funcionan estos update

claro si tambien lo intente y eso es lo mas factible ahora que me lo dices.

mi problema es que no me ejecuta las consultas osea no me hace los updates
  #7 (permalink)  
Antiguo 30/06/2010, 10:25
 
Fecha de Ingreso: julio-2009
Mensajes: 29
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: no me funcionan estos update

mira tengo este otro codigo que esta un poco mejorado pero tengo el problemas de que me envia las comas (,)

$sql = "UPDATE `productos` SET ";
$sql .= $titulo_modificado == "true" ? "titulo = '".$titulo."', " : "";
$sql .= $categoria_modificado == "true" ? " id_categoria = '".$id_categoria."', " : "";
$sql .= $imagen_modificado == "true" ? "url_imagen = '".$nombre_archivo."' " : "";
$sql .= "WHERE id = '$id_registro' LIMIT 1";

no me hace la discriminacion de poder modificar 1, 2 o los 3 campos.
  #8 (permalink)  
Antiguo 30/06/2010, 11:20
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: no me funcionan estos update

Cita:
Iniciado por emstro Ver Mensaje
GatorV, el error no pasa por eso ya que php lee de igual manera esa variable .

vemon_mau, no creo que sea asi gracias de todas maneras.
Sí PHP lee la variable pero también te arroja un E_NOTICE, y un E_WARNING, y en versiones posteriores de PHP es probable que quiten ese comportamiento, así que es mejor escribir código bien, con el símbolo $ para delimitar que es una variable.

Saludos.
  #9 (permalink)  
Antiguo 30/06/2010, 11:34
 
Fecha de Ingreso: julio-2009
Mensajes: 29
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: no me funcionan estos update

GatoV, gracias por tu aclaracion

Etiquetas: funcionan, update
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 21:35.