在mysql中我有一列字段,字段类型是Decimal,保留了2位小数,我想过滤这2位小数中不为0的数字,如何过滤呢?

直接看SQL如何实现

SELECT * FROM your_table_name WHERE amount - FLOOR(amount) > 0;

解释

这里的FLOOR(amount)函数会返回amount的整数部分,amount - FLOOR(amount)就会得到小数部分。如果小数部分大于0,表示这个数字的小数部分不为0

扩展

如果想要确保考虑到精度问题,特别是在涉及到金融数值时,您还可以这样写:

SELECT * FROM your_table_name WHERE ROUND(amount, 2) - ROUND(FLOOR(amount), 2) > 0;

这里使用ROUND()函数确保数字四舍五入到2位小数后再进行比较,避免了由于存储或计算精度问题导致的错误过滤。记得替换your_table_name为您实际的表名。

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术武器库

一句真诚的谢谢,胜过千言万语

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值