Ver Mensaje Individual
  #7 (permalink)  
Antiguo 24/02/2014, 09:46
Avatar de Yoss15
Yoss15
 
Fecha de Ingreso: octubre-2007
Mensajes: 11
Antigüedad: 16 años, 6 meses
Puntos: 0
Respuesta: Consulta con Condicionales entre tipo de Datos Float

Me da el exactamente el mismo resultado que cuando aplicaba mi select inicial, me excluye aquellas filas cuando ambos son ceros, pero ademas aquellas que en alguno de los casos es cero.

Es decir me arroja los siguiente:

ncuenta montopres montogasto
001 15.00000 14.00000
004 26.00000 14.00000

Y necesito que se muestren tambien aquellas donde uno de sus valores sea cero .

=(

Pero estuve leyendo y tiene que ver con el tipo de dato que es FLoat, aparentemente cuando se aplica un condicional a ese tipo de dato la consulta podria no arrojar los resultados correctos..

Aqui el link donde lei sobre eso,.



Utilizar datos float y real




Los tipos de datos float y real se conocen como tipos de datos aproximados. El comportamiento de float y real sigue la especificación IEEE 754 acerca de los tipos de datos numéricos aproximados.

Los tipos de datos numéricos aproximados no almacenan los valores exactos especificados para muchos números; almacenan una aproximación muy precisa del valor. Para muchas aplicaciones, la pequeña diferencia entre el valor especificado y la aproximación almacenada no es apreciable. Sin embargo, a veces la diferencia se hace notar. Debido a la naturaleza aproximada de los tipos de datos float y real, no los use cuando necesite un comportamiento numérico exacto, como, por ejemplo, en aplicaciones financieras, en operaciones que conlleven un redondeo o en comprobaciones de igualdad. En su lugar, use los tipos de datos enteros, decimal, money o smallmoney.

Evite usar columnas float o real en las condiciones de búsqueda de la cláusula WHERE, especialmente los operadores = y <>. Es aconsejable limitar las columnas float y real a las comparaciones > o <.


La especificación IEEE 754 proporciona cuatro modos de redondeo: redondear al más cercano, redondear hacia arriba, redondear hacia abajo y redondear a cero. Microsoft SQL Server utiliza el redondeo hacia arriba. Todos son precisos para garantizar la exactitud, aunque pueden dar como resultado valores en punto flotante ligeramente distintos. Puesto que la representación binaria de un número en punto flotante puede usar cualquiera de los esquemas válidos de redondeo, no se puede cuantificar de forma precisa un valor en punto flotante.

SAcado de :
http://technet.microsoft.com/es-es/library/ms187912%28v=sql.105%29.aspx


Pero pienso que debe existir una manera de poder hacer este filtro sin alterar la naturaleza de la tabla de la BD.