关联模型多对多更新出错

浏览:765 发布日期:2013/10/22 分类:求助交流 关键字: 关联模型 多对多
看了教程、视频还有源码,很乱,头晕地乱。
一开始无法更新数据,按照教程和视频的配置方式,无论关联数据配置成
$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
最佳答案
评论( 相关
后面还有条评论,点击查看>>