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

$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

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

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

浮点数转换为字符串试试

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

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

2年前 评论

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

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

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