数据库返回的整型数据被偷换成了字符串类型

更新日期: 2016-07-07 阅读次数: 8631 分类: Laravel

在实现一个多级菜单功能时,发现 Laravel 从 MySQL 获取的整型数据被转换成了 string 类型, 导致使用 collection filter 无法得到对应的数据。但是并不是在所有机器上都能出现,只有在服务器上才会

开发机 (Mac / Ubuntu 16.04)

[2016-07-07 08:17:43] local.INFO: [{"id":1,"level":1}]

生产环境 (Ubuntu 12.04)

[2016-07-07 09:06:07] local.INFO: [{"id":1,"level":"1"}]

可以看到,代表菜单层级的 level 字段,在生产环境中变成了字符串。

确认了表结构没有问题,说明问题出在了数据被取出来的过程中。于是 Google 了一下,发现问题出在了 PHP 的 MySQL 驱动上

而在 PHP 5.3 版本之后则不会出现该问题,于是更新 PHP 的 MySQL 驱动

sudo apt-get update
sudo apt-get install php5-mysqlnd

无需重启 Nginx, 再次测试,发现一切正常,说明问题解决

[2016-07-07 09:22:38] local.INFO: [{"id":1,"level":1}]

谈笑风生

laravel

有个问题,laravel的php版本最低5.4,那为什么会出现这个问题呢?

大象腿

确实,我回头查一下

爱评论不评论

近期节日

2020年04月11日 世界帕金森病日
2020年04月19日 谷雨
2020年04月21日 复活节
2020年04月22日 世界地球日
2020年04月23日 世界读书日
2020年04月26日 知识产权日
2020年04月30日 佛诞
2020年04月30日 全国交通安全反思日
2020年05月01日 国际劳动节
2020年05月04日 五四青年节
2020年05月05日 立夏
2020年05月08日 世界红十字日
查看更多节日