一开始无法更新数据,按照教程和视频的配置方式,无论关联数据配置成
$data["users"] = array (
array("uid"=>91),
array("uid"=>92),
)
还是
$data["users"] = array (
0=>91,
1=>92
)
还是
$data["users"] = array (
0=>"91",
1=>"92"
)
第1和2中方式获取到的数据是空的,第三种方式获取到的关联数据是9和9,不是91和92.
后来实在不行查看源码,RelationModel.class.php,发现通过mapping_key这个字段去获取数据的,详见关键行
foreach ($mappingData as $vo)
$ids[] = $vo[$mappingKey];
追查这个$mappingKey,会找到上方获取定义的
$mappingKey =!empty($val['mapping_key'])? $val['mapping_key'] : $this->getPk(); // 关联键名
遂在配置里面增加mapping_key属性。好了,中间表数据获取到了。
但是,问题又来了,这个$mappingKey又作为获取主表的主键字段名,崩溃了。
源码如下:
// 当前数据对象主键值
$pk = $data[$mappingKey];
这个$pk将作为从更新的数据中获取主键值用的,god,这就歇菜了。
请问谁用ThinkPHP写过大型软件,多对多模型正常使用?有用吗?
我下载的版本是ThinkPHP3.1.3_full.zip
最佳答案