TP5数据库表字段大小写的问题,是否BUG(附解决方法)

浏览:4436 发布日期:2016/04/29 分类:ThinkPHP5专区
TP5数据库表字段大小写的问题,是否有个BUG(附解决方法)

TP5 RC3 版本:时间为2016/4/28 08:15

因历史原因,我的项目数据库中的表字段为大小写混合模式,在数据库链接中已经设定PDO::ATTR_CASE => PDO::CASE_NATURAL,这时查出来的字段为大小写混合的原始模式,但在INSERT和UPDATE数据时,出错,出错信息为找不到大小写混和的字段,如下图



分析TP5 RC3原码 发现在thinkphp\library\think\db\Connection.php中有两个函数connect、fieldCase在对$params使用时有数据不一致的情况

如185行,虽然对$params进行了加工,但并没有将加工后的$params传到“上级”,如下图

导致在fieldCase函数中对$params使用时仍使用未加工过的,签于此情况,建议在186行插入代码:$this->params = $params;如下图


至此大小写混合的模式的字段在查询和变更的BUG被彻底解决。此方法是否可行,请官方指导一下,多谢!
最佳答案
评论( 相关
后面还有条评论,点击查看>>