搜索
系统检测到您的用户名不符合规范:

关于关联模型save/add/del操作中的一个bug

浏览:1074 发布日期:2015年03月23日 分类:技术分享 关键字: BUG
TP 版本: 3.2.3

BUG描述:多对多表关联时,对中间表的插入和修改操作时,当插入的id大于10时出现错误

BUG还原:

表关系://产品表
create table dj_product (
id int primary key auto_increment,
...
);
//目的地表
create table dj_product_destination (
int primary key auto_increment,
...
);
//产品目的地中间表
create table dj_product_with_destination (
int primary key auto_increment,
destination_id int,
product_id int
);
定义关联模型//省略包名及导入类库
class ProductModel extends RelationModel{

Protected $tableName = 'dj_product'; //主表名
Protected $_link = array(
'dj_product_destination' => array( //目的地
'mapping_type' => self::MANY_TO_MANY,
'foreign_key' => 'product_id',
'relation_foreign_key' => 'destination_id',
'relation_table' => 'dj_product_with_destination',

),
);
}
定义action//省略包名及导入类库
class ProductController extends Controller {
public function addProduct($product_id = 0){
D('Product')->Relation(true)->where(array('id'=>$product_id))->save($_POST);
}
}
发送请求
http://servername/modulename/Product/addProduct.html
post表单参数:product_id=1&dj_product_destination[]=9&dj_product_destination[]=19

最后数据库保存的结果select * from dj_product_with_destination;

id, destination_id, product_id
1 1 1
2 9 1
BUG 原因 :

RelationModel.class.php 第337行 至 342行 有问题 if(is_array($mappingData)) {
$ids = array();
foreach ($mappingData as $vo)
$ids[] = $vo[$mappingKey];
$relationId = implode(',',$ids);;
}
此段拼接关联表(dj_product_destination)id 出错。

当id大于10时,$relationId结果异常。

最佳答案
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
guoweisharp
积分:183 等级:LV1
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /