如何从不直接相关的表中获取数据Yii2

时间:2016-11-11 13:55:49

标签: php yii2

我有3个班级Persona,Alumno和factura。我需要使用gridview和搜索功能在factura上显示person fullname。全名在Persona中。 Factura只通过id_alumno与alumno相关,alumno通过id_persona与persona相关。 我尝试通过创建一个新的变量fullname和一个函数来解决这个问题,以便在类factura上获得角色。

class Factura extends \yii\db\ActiveRecord{
     public $full_name;

}
public static function tableName()
{
    return 'factura';
}
public function rules()
{
return [
  [['id_factura_reemplazo', 'id_obra_social', 'id_alumno',], 'integer'],
  [['id_obra_social', 'id_alumno'], 'required'],
  [['fecha_factura','fullname','id_persona'], 'safe'],
];
}
public function attributeLabels()
{
return [
  'id_factura' => 'Id Factura',
  'id_factura_reemplazo' => 'Id Factura Reemplazo',
  'id_obra_social' => 'Id Obra Social',
  'id_alumno' => 'Id Alumno',
  'fullName'=>Yii::t('app', 'Nombre y Apellido'),
  ];
}
public function getIdAlumno()
{
    return $this->hasOne(Alumno::className(), ['id_alumno' => 'id_alumno']);
}
public function getIdPersona() {
   return $this->hasOne(Persona::className(), ['id_persona' => 'id_persona'])
   ->via('idAlumno');
}

public function getFullname(){
  return $this->idPersona->nombre." ".$this->idPersona->apellido;
}

我在返回线上得到错误。

PHP注意 - yii \ base \ ErrorException

尝试获取非对象的属性

public function getFullname(){
   return $this->idPersona->nombre." ".$this->idPersona->apellido;
}

第一个问题修复

现在我得到: 无效的调用 - yii \ base \ InvalidCallException

设置只读属性:app \ models \ Facturasearch :: fullName

 if (method_exists($this, 'get' . $name)) {
        throw new InvalidCallException('Setting read-only property: ' .       get_class($this) . '::' . $name);
    } else {
        throw new UnknownPropertyException('Setting unknown property: ' . get_class($this) . '::' . $name);
    }

它就像它没有吸气剂......当它试图做$ this-> load($ params);

时问题从线上跳了出来
class Facturasearch extends Factura{    
public function rules()
{
    return [
        [['id_factura', 'id_factura_reemplazo',  'id_alumno', 'numero'], 'integer'],
        [['id_obra_social','fecha_factura', 'observacion','id_alumno','fullName','id_persona'], 'safe'],
    ];
}

public function search($params)
{
    $query = Factura::find();

    $dataProvider = new ActiveDataProvider([
        'query' => $query,
    ]);

    $this->load($params);
    ...

1 个答案:

答案 0 :(得分:1)

在尝试访问关系之前,最好首先检查是否获取了属性:

public function getFullname()
{
    if ($this->idPersona) {
        return $this->idPersona->nombre." ".$this->idPersona->apellido;
    }
    return null;
}

但这不是问题所在。看起来关系配置不正确。

如果Alumno模型表中的主键确实是id_alumnoPersona模型表中的主键确实是id_persona,则关系可能设置正确但通常是主键仅命名为id,在这种情况下,关系应为:

public function getIdAlumno()
{
    return $this->hasOne(Alumno::className(), ['id' => 'id_alumno']);
}

public function getIdPersona()
{
    return $this->hasOne(Persona::className(), ['id' => 'id_persona'])->via('idAlumno');
}

如果是这种情况,上述情况应该有所帮助。如果没有 - 请告诉我。