Foros del Web » Programando para Internet » PHP »

UPDATE (actualizar registro usando SELECT dentro de UPDATE

Estas en el tema de UPDATE (actualizar registro usando SELECT dentro de UPDATE en el foro de PHP en Foros del Web. Hola amigos. Veran... tengo que actualizar un registro usando (UPDATE), pero antes tengo que extraer el valor del campo "CONTADOR" , sumarle " +1 "y ...
  #1 (permalink)  
Antiguo 13/02/2014, 01:03
Avatar de OgaTatsumi  
Fecha de Ingreso: agosto-2011
Ubicación: Japon.
Mensajes: 5
Antigüedad: 12 años, 8 meses
Puntos: 1
UPDATE (actualizar registro usando SELECT dentro de UPDATE

Hola amigos.
Veran... tengo que actualizar un registro usando (UPDATE), pero antes tengo que extraer el valor del campo "CONTADOR", sumarle "+1"y posteriormente hacer el UPDATE, para sumarle solo +1.

Asi:
Código MySQL:
Ver original
  1. //Aqui uso un SELECT para sacar el resultado del campo contador
  2. //despues sumo +1
  3. //Ahora si actualizo
  4.  
  5. mysql_query ("UPDATE capitulos SET contador = $cont+1 WHERE cap = $cap AND id = $id");

Pero quiero saber si hay alguna manera de no hacer el SELECT o bien, hacerlo adentro del UPDATE...

Lo intente asi:

Código PHP:
Ver original
  1. mysql_query ("UPDATE capitulos SET contador = (SELECT contador FROM capitulos WHERE cap = $cap AND id = $id) +1 WHERE cap = $cap AND id = $id");
  2. //Asi
  3. mysql_query ("UPDATE capitulos SET contador = (SELECT contador FROM capitulos) +1 WHERE cap = $cap AND id = $id");
  4. //y asi
  5. mysql_query ("UPDATE capitulos SET contador = contador+1 WHERE cap = $cap AND id = $id");
Y como esperaria... no funcionaa...

Podrian ayudarme?... De antemano, Gracias por su ayuda.
  #2 (permalink)  
Antiguo 13/02/2014, 01:51
Avatar de Alexis88
Philosopher
 
Fecha de Ingreso: noviembre-2011
Ubicación: Tacna, Perú
Mensajes: 5.552
Antigüedad: 12 años, 5 meses
Puntos: 977
Respuesta: UPDATE (actualizar registro usando SELECT dentro de UPDATE

La tercera forma es la correcta, quizá se te escapó algún detalle fuera de esa sentencia o probablemente el tipo del campo "contador" no sea numérico. En otras páginas también recomiendan hacerlo así, incluso en el manual oficial de MySQL:

- Incrementar campo de MySQL con un único update
- Increment value in mysql update query
- Sintaxis de UPDATE (Manual oficial de MySQL)

Revisa bien tu código y los datos en la BD, lo más probable es que se te esté escapando algún detalle que no logres ver a simple vista.

Saludos
__________________
«Juro por mi vida y mi amor por ella, que jamás viviré para el provecho de otro hombre, ni le pediré a otro hombre que viva para el mío».

Ayn Rand

Etiquetas: mysql, registro, select, update, usando
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 15:47.