Yii2通过表对链接表进行排序和过滤

时间:2018-07-04 15:35:02

标签: yii2 yii2-advanced-app yii2-model

大家好。我正在尝试为关联的phone_digital字段添加过滤器,但出现以下错误enter image description here

结构-

1个表格-ClientClient-名字,名字,姓氏,年龄。
2表-ClientPhone-client_id,phone_digital。

ClientClient(模型)

class ClientClient extends \yii\db\ActiveRecord
{
public static function tableName(){
    return 'client_client';
}
public function rules(){
    return [
        [['age'], 'integer'],
        [['first_name', 'patronymic', 'last_name'], 'string', 'max' => 255],
    ];
}
public function attributeLabels(){
    return [
        'id' => 'ID',
        'first_name' => 'First Name',
        'patronymic' => 'Patronymic',
        'last_name' => 'Last Name',
        'age' => 'Age',
        'phone_digital' => 'Phone Digital',
    ];
}
public function getclientPhone(){
    return $this->hasOne(clientPhone::class, ['client_id' => 'id']);
}
public function getPhone(){
    return $this->hasOne(clientPhone::class, ['phone_digital' => 'id']);
}
public function getDigital(){
    return $this->hasOne(ClientPhone::className(), ['id' => 'phone_digital']);
}
public function getPhoneDigital(){
    return $this->phone->phone_digital;
}
}

ClientSearch(模型)

class ClientSearch extends Clientclient
{
public $phonedigital;
public function rules(){
    return [
        [['id', 'age'], 'integer'],
        [['first_name', 'phonedigital', 'patronymic', 'last_name'], 'safe'],
    ];
}
public function scenarios(){
    // bypass scenarios() implementation in the parent class
    return Model::scenarios();
}
public function search($params){
    $query = Clientclient::find()->orderBy('phone_digital');
    $dataProvider = new ActiveDataProvider([
        'query' => $query,
        ]);
    if (!($this->load($params) && $this->validate())) {
        return $dataProvider;
    }
    $query->joinWith(['phonedigital' => function($query) { $query->from(['phonedigital' => 'ClientPhone']); }]);
    $dataProvider->sort->attributes['phone'] = [
        'asc' => ['phonedigital.phone_digital' => SORT_ASC],
        'desc' => ['phonedigital.phone_digital' => SORT_DESC],
    ];
    $query->andFilterWhere([
        'id' => $this->id,
        'age' => $this->age,
    ]);
    $query->andFilterWhere(['like', 'first_name', $this->first_name])
        ->andFilterWhere(['like', 'patronymic', $this->patronymic])
        ->andFilterWhere(['like', 'last_name', $this->last_name])
        ->andFilterWhere(['like', 'phonedigital.phone_digital', $this->getAttribute('phonedigital')]);

    return $dataProvider;
}
}

我需要做什么才能使这项工作成功?

1 个答案:

答案 0 :(得分:0)

我想您应该在加入后下订单 检查评论的行:

public function search($params){
// do not put the join of a related table at the beginning because it's not related yet
    $query = Clientclient::find(); 
    $dataProvider = new ActiveDataProvider([
        'query' => $query,
        ]);
    if (!($this->load($params) && $this->validate())) {
        return $dataProvider;
    }
    $query->joinWith(['phonedigital' => function($query) { $query->from(['phonedigital' => 'ClientPhone']); }]);

// orderBy only after call the relacion
    $query->orderBy('phonedigital.phone_digital'); 

    $dataProvider->sort->attributes['phone'] = [
        'asc' => ['phonedigital.phone_digital' => SORT_ASC],
        'desc' => ['phonedigital.phone_digital' => SORT_DESC],
    ];
    $query->andFilterWhere([
        'id' => $this->id,
        'age' => $this->age,
    ]);
    $query->andFilterWhere(['like', 'first_name', $this->first_name])
        ->andFilterWhere(['like', 'patronymic', $this->patronymic])
        ->andFilterWhere(['like', 'last_name', $this->last_name])
        ->andFilterWhere(['like', 'phonedigital.phone_digital', $this->getAttribute('phonedigital')]);

    return $dataProvider;
}

希望对您有所帮助,对我的单身感到抱歉