Foros del Web » Programando para Internet » PHP »

ayuda con este update

Estas en el tema de ayuda con este update en el foro de PHP en Foros del Web. tengo una tabla llamada facturas2, la cual contiene los campos: id_articulo, id_requisicion, unidad, descripcion, cantidad y otra tabla llamada activo en la cual los campos ...
  #1 (permalink)  
Antiguo 13/01/2010, 11:01
(Desactivado)
 
Fecha de Ingreso: septiembre-2009
Mensajes: 26
Antigüedad: 14 años, 7 meses
Puntos: 0
Exclamación ayuda con este update

tengo una tabla llamada facturas2, la cual contiene los campos: id_articulo, id_requisicion, unidad, descripcion, cantidad

y otra tabla llamada activo en la cual los campos que tiene parecidos o con el mismo nombre es descripcion y cantidad.

tengo que hacer una consulta en la cual selecciono de la tabla facturas2 el valor mas grande que esta en id_requisicion y al tenerlo seleccionado restarle la cantidad que tiene el campo de cantidad de la tabla facturas2, al campo cantidad de la tabla activo, claro esta que para que esto suceda estos deben tener el campo descripcion entrelazados o pues que no se le reste a ninguno otro articulo sino es esa descripcion que se describe en facturas2 con el numero mayor de id_requisicion y la cantidad.

no se si me di a entender,

seria algo asi

facturas2
|id_articulo | id_descripcion | unidad | descripcion | cantidad|
````````````````````````````````````````````````
1---------------1--------UND-----Licencia-----2
2---------------2--------UND-----Licencia-----2
3---------------2--------UND-----Mouse-------2

activos
| descripcion | cantidad|
```````````````````
Licencia--------4
Mouse----------4
Cd--------------5
Teclado---------7

la consulta deberia decir que coge el numero mayor de facturas del campo id_requisicion la cogerlo compara que los campos descripcion de las dos tablas sean igual y que al ser iguales le resta el valor de la columna cantidad ubicada en facturas2 al campo cantidad de activos que dando asi:

activos
| descripcion | cantidad|
```````````````````
Licencia--------2
Mouse----------2
Cd--------------5
Teclado---------7

claro esta que hago el select max a id_descripcion y me dice que el numero mayor es 2 en este ejemplo pero no se si hacer ese select mas el update de resta se realize bien la actualizacion de los datos con id_requisicion 2

Última edición por anwardacosta; 13/01/2010 a las 13:15 Razón: correcion
  #2 (permalink)  
Antiguo 13/01/2010, 11:06
Avatar de FNX_NET  
Fecha de Ingreso: marzo-2004
Ubicación: EN EL INFIERNO.....
Mensajes: 1.707
Antigüedad: 20 años
Puntos: 7
Respuesta: ayuda con este update

hace un inner join y luego puedes hacer una resta entra (cantidad1 - cantidad2) as total
__________________
:-D "Que se libere del cielo confinado; que mi cuerpo sea la espada de hielo negro que nos lleve al abismo; que ningún poder pueda detenernos...Destructora de las almas de los dioses!!!":adios:


:pirata:
  #3 (permalink)  
Antiguo 13/01/2010, 11:41
(Desactivado)
 
Fecha de Ingreso: septiembre-2009
Mensajes: 26
Antigüedad: 14 años, 7 meses
Puntos: 0
Respuesta: ayuda con este update

FNX_NET

pero como hago ese inner join no es mas facil con una consulta ? estoy leyendo y es con Max(campo) pues si lo seleccion pero no se como hago para la resta y que los campos descripcion sean los mismos de las dos tablas y se haga toda la operacion sin restarle a los demas articulos en la tabla articulo,solo a los que sean el numero mayor

Última edición por anwardacosta; 13/01/2010 a las 16:07 Razón: correcion
  #4 (permalink)  
Antiguo 19/01/2010, 07:02
Avatar de masterojitos  
Fecha de Ingreso: julio-2008
Ubicación: Lima Callao Chucuito
Mensajes: 1.931
Antigüedad: 15 años, 8 meses
Puntos: 105
Respuesta: ayuda con este update

1. tienes que extraer la descripcion y cantidad de la factura con el id_descripcion igual al maximo.... para ello lo haces mas simple con un select anidado.
2. ya con esto... recorres este select, para poder realizar tu update a tu tabla activos.
3. actualizas la cantidad restando la cantidad actual de la tabla activos con la cantidad correspondiente al bucle anterior dependiendo de la descripcion.

Bueno es algo enrredado.... pero espero con el codigo siguiente lo entiendas mejor.

Código PHP:
Ver original
  1. <?php
  2. //.....conexion
  3. $rs = mysql_query("select descripcion, cantidad from facturas2 where id_descripcion = (select max(id_descripcion) from facturas2)");
  4. while($row = mysql_fetch_array($rs)){
  5.     mysql_query("update activos set cantidad = (cantidad - ".$row['cantidad'].") where descripcion = '".$row['descripcion']."'");
  6. }
  7. ?>

Suerte.
__________________
Atte. MasterOjitos :ojotes:
Todo sobre Programación Web
Las ultimas tendencias en Efectos y Recursos Web: MasterOjitos Blog
  #5 (permalink)  
Antiguo 19/01/2010, 13:42
Avatar de masterojitos  
Fecha de Ingreso: julio-2008
Ubicación: Lima Callao Chucuito
Mensajes: 1.931
Antigüedad: 15 años, 8 meses
Puntos: 105
Respuesta: ayuda con este update

aunque quizas va llegar algun momento en que la resta salga negativa y te lanzaria error...... para ello primero deberias validar la resta...... aqui va el codigo mejorado........

Código PHP:
Ver original
  1. <?php
  2. //.....conexion
  3. $rs = mysql_query("select descripcion, cantidad from facturas2 where id_requisicion = (select max(id_requisicion) from facturas2)");
  4. while ($row = mysql_fetch_array($rs)){
  5.     $cantidad_activo = mysql_result(mysql_query("select cantidad from activo where descripcion = '".$row['descripcion']."'"), 0);
  6.     $cantidad_actual = ($cantidad_activo > $row['cantidad']) ? ($cantidad_activo - $row['cantidad']) : 0;
  7.     mysql_query("update activo set cantidad = '$cantidad_actual' where descripcion = '".$row['descripcion']."'") or die (mysql_error());
  8. }
  9. ?>

Espero ahora si te sirva.

Suerte.
__________________
Atte. MasterOjitos :ojotes:
Todo sobre Programación Web
Las ultimas tendencias en Efectos y Recursos Web: MasterOjitos Blog

Etiquetas: 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 22:31.