Ver Mensaje Individual
  #14 (permalink)  
Antiguo 14/12/2014, 08:15
Avatar de gnzsoloyo
gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 16 años, 5 meses
Puntos: 2658
Respuesta: no consigo haer funcionar a sum()

Cita:
Iniciado por gralf Ver Mensaje
Yo si no me afecta a mis cuentas, que es lo que entiendo que haceis, lo dejo así.

Pero el probl!ma del error en sum, tiene arreglo?
Lo que tienes no es un problema de consulta, sino una inconsistencia de datos...

Según lo que posteaste, lo que tienes en esa tabla es esto:
Código MySQL:
Ver original
  1. mysql> use stocklentesbrujuleando3
  2. Database changed
  3. mysql> SELECT
  4.     ->     id_item,
  5.     ->     IFNULL(compra, 0) compra,
  6.     ->     IFNULL(taller, 0) taller,
  7.     ->     IFNULL(venta, 0) venta,
  8.     ->     IFNULL(regula_mas, 0) regula_mas,
  9.     ->     IFNULL(regula_menos, 0) regula_menos
  10.     ->   FROM movimiento ;
  11. +---------+--------+--------+-------+------------+--------------+
  12. | id_item | compra | taller | venta | regula_mas | regula_menos |
  13. +---------+--------+--------+-------+------------+--------------+
  14. |       1 |    100 |      0 |     0 |          0 |            0 |
  15. |       1 |      0 |      2 |     0 |          0 |            0 |
  16. |       1 |      0 |      0 |     1 |          0 |            0 |
  17. |     352 |     58 |      0 |     0 |          0 |            0 |
  18. |     352 |      0 |      0 |     0 |          0 |           12 |
  19. |       1 |      0 |      0 |   125 |          0 |            0 |
  20. +---------+--------+--------+-------+------------+--------------+
  21. 6 rows in set (0.00 sec)
Si te fijas con cuidado, en el último movimiento tienes una venta de 125 unidades, pero sólo 100 en stock (primer registro)
Sencillamente tienes un error de aplicación porque no estás validando que existan unidades en stock antes de realizar la venta...

Por otro lado, observando tus tablas, quisiera hacerte una aclaración...
Ese número "(5)" que estás poniendo es un error porque no representa la cantidad de dígitos que se almacenan. Eso se usa para otras cosas, y eventualmente puede causarte problemas.

Este es un tema recurrente, y para el caso aplica lo que dice el manual de referencia:
Cita:
MySQL supports an extension for optionally specifying the display width of integer data types in parentheses following the base keyword for the type. For example, INT(4) specifies an INT with a display width of four digits. This optional display width may be used by applications to display integer values having a width less than the width specified for the column by left-padding them with spaces. (That is, this width is present in the metadata returned with result sets. Whether it is used or not is up to the application.)

The display width does not constrain the range of values that can be stored in the column. Nor does it prevent values wider than the column display width from being displayed correctly. For example, a column specified as SMALLINT(3) has the usual SMALLINT range of -32768 to 32767, and values outside the range permitted by three digits are displayed in full using more than three digits.
Esto que te resalto dice: "El valor mostrado no restringe el rango de valores que pueden ser almacenados en la columna. Tampoco previene que valores mayores de la columna sean mostrados correctamente".
El único uso que tiene ese numero es para que ciertas aplicaciones que sólo tienen un rango dado fijo de salida, puedan recibir la columna "formateada" adecuadamente, pero no representa al dato.
El rango del dato está dado por su tipo de columna. Lo correcto es que un INT UNSIGNED tenga un ancho de salida de 10, cosa que MySQL pone automáticamente si sólo le indicas el tipo de dato, sin ese valor.

Por otro lado, como ciertas funciones de MySQL leen esa definición de ancho para ciertas tareas (generación de vistas, por ejemplo), podría darse que valores mayores sean leídos incorrectamente, dando resultados erróneos en las consultas, porque MySQ "cortaría" el número, descartando parte de su valor.

En síntesis: No los uses. Deja que MySQL ponga el que corresponda.

Sí se usan con los DECIMAL, pero eso es otro caso completamente distinto, y alli sí tiene sentido usarlos.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)