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被彻底解决。此方法是否可行,请官方指导一下,多谢!
最佳答案