mysql的float类型很奇怪的,2个值不相等

WBOY
풀어 주다: 2016-06-23 13:33:00
원래의
1159명이 탐색했습니다.

表有很多数据,可有几条很奇怪,字段是float类型,2个值相同

Payment 值=299.7
feiyong 值=299.7

查询语句:feiyong>0 and Payment>0 and Payment
这时还是能查询出来,而且只是有几条有这问题,其他的都正常


回复讨论(解决方案)

浮点数为表示很大的数,丢失了部分精度
所以在比较时应用: 两个数的差的绝对值小于某个极小数时就视为相等 的策略
或者用 round 取得有效数后在比较
如果你的应用需要有精确的小数位数(比如金融)那么应该使用 DECIMAL 类型

这个还是蛮正常的  毕竟float数据没有办法保证数据的精度呢

浮点数为表示很大的数,丢失了部分精度
所以在比较时应用: 两个数的差的绝对值小于某个极小数时就视为相等 的策略
或者用 round 取得有效数后在比较
如果你的应用需要有精确的小数位数(比如金融)那么应该使用 DECIMAL 类型



那现在查询语句要怎么改才能正常查询,谢谢

建议修改类型为DECIMAL

select ..., abs(Payment-feiyong) as aform ......where feiyong>0 and Payment>0having a > 1e-5
로그인 후 복사

select ..., (Payment-feiyong) as aform ......where feiyong>0 and Payment>0having a > 1e-5
로그인 후 복사

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿