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

jerry thinkphp 2015年11月19日 收藏
先前使用关联模型的时候出现增加没有问题,但是 删除和修改 的时候出现了不同步的原因。

大家可以加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',
        )
    );