好神奇 为什么模型查询数据不稳定喃?

$find=User::query()->where(['m'=>735,'c'=>7,'t'=>1,'w'=>1.77,'l'=>1.91,'a'=>'2022-06-26 00:05:30'])->first();
dd($find);

直接数据库执行该SQL是有数据的 为什么上面这个查询不出来数据

测试的时候
1.我把字段a 去掉了 竟然可以查询到数据
2.我把字段l 去掉了 竟然也可以查询到数据
3.我把数据库w 和 l 字段从double改成decimal也可以查询出来数据 究竟是哪儿的问题喃?

百度了一下 好像问题是Laravel 查询条件为浮点的问题 有遇到过吗 怎么解决的喃

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 13

在 mysql 中,字段类型为 float 的字段,如果不指定 float 的长度和小数点位数,要根据 float 字段的值精确查找,结果会是空,原因是在 mysql 中,float 是浮点数,mysql 存储的时候是近似值,所以用精确查找无法匹配;但可以用 like 去匹配。

3年前 评论

你可以打印出来 sql 在数据库工具执行查询,如果同样的 sql 哪里可以这样查不行,就是类型转换的问题

3年前 评论
tiantian10000 (楼主) 3年前

浮点数转换为字符串试试

3年前 评论
tiantian10000 (楼主) 3年前

阿里Java开发手册要求浮点型字段一定要用decimal类型,不要使用float

3年前 评论
tiantian10000 (楼主) 3年前
tiantian10000 (楼主) 3年前
勇敢的心 (作者) 3年前
tiantian10000 (楼主) 3年前
勇敢的心 (作者) 3年前
tiantian10000 (楼主) 3年前
tiantian10000 (楼主) 3年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!