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

3.2.2模型关联condition条件使用变量方法

浏览:4107 发布日期:2014年10月24日 分类:用法示例
先前使用关联模型的时候出现增加没有问题,但是 删除和修改 的时候出现了不同步的原因。

大家可以加QQ群 161607701 ,大家共同学习PHP技术!

说明:
$_link 内如果设置了条件的话就会出现以上问题。
我是只配置了 一对一 其他我没有测试哦。因为我只用到了一对一表。
解决办法如下
打开:TP/Library/Think/Model/RelationModel.class.php 文件
查找 一下代码: if(!empty($val['condition'])) {
$mappingCondition = $val['condition'];
}else{
$mappingCondition = array();
$mappingCondition[$mappingFk] = $pk;
}
修改为: $mappingCondition = array();
if(!empty($val['condition'])) {
if(!empty($val['is_key'])){
$mappingCondition = $this->get_condition($val['condition']);
}else{
$mappingCondition = $this->get_condition($val['condition']);
$mappingCondition[$mappingFk] = $pk;
}
}else{
$mappingCondition[$mappingFk] = $pk;
}
在最后加入一个方法 /**
* @param $condition 条件
* @return array
*/
protected function get_condition($condition){
$wherearr = explode('and',$condition);
$mappingCondition = array();
foreach($wherearr as $value){
$value = trim($value);
list($key,$v) = explode('=',$value);
$key = trim($key);
$v = str_replace('"','',str_replace('\'','',trim($v)));
$mappingCondition[$key] = $v;
}
return $mappingCondition;
}
由于增加了一个参数 is_key
需要 配置一下。
'is_key' => false在配置关联表的时候 condition 会自动带着 主表ID 作为条件。
'is_key' => true, 和 thinkPhp 默认的一样了,就会是你 配置的 condition 参数内作为条件。 //数据关联
protected $_link=array(
'Keyword'=>array(
'mapping_type' => self::HAS_ONE,
'class_name' =>'Common/Keyword',
'foreign_key' => 'mod_id',
'is_key' => false,
'mapping_fields'=> 'keyword,mod_name,match_type',
'condition' => 'mod_name = "TextReply"',
'as_fields' => 'keyword,mod_name,match_type',
)
);
收藏
807735
积分:2969 等级:LV3
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

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

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