Yii 2:ActiveRecords中的虚拟字段

时间:2015-03-30 11:21:40

标签: php mysql activerecord yii2

我使用MySQL和Yii 2.在数据库中存在table 'Regions' with column 'coordinates'。此列的类型为point。

在SQL中我可以写: "SELECT X(coordinates) as x, Y(coordinates) as y""INSERT INTO Regions SET coordinates = PointFromText('POINT(".$x." ".$y.")')"

但我不知道如何制作ActiveRecord模型。我想要这个(数据库不变):

$item = Regions::findOne(1);
echo $item->x." ".$item->y;
$item->x = $new_x;
$item->y = $new_y;
$item->save(); // data saved in 'coordinates' column

方法'set...()''get...()'无法帮助我。我想避免对数据库进行额外的查询。

请帮我做。

1 个答案:

答案 0 :(得分:1)

你可以像Yii2一样:

public $longitude, $latitude;

/**
 * @inheritdoc
 */
public function beforeSave($insert)
{
    $this->location = new \yii\db\Expression("GeomFromText(:point)", [
        ':point'=>'POINT('. $this->longitude.' '.$this->latitude.')'
    ]);
    return parent::beforeSave($insert);
}


/**
 * @inheritdoc
 */
public static function find()
{
    return parent::find()->select([
        '*', 'X(location) as longitude', 'Y(location) as latitude'
    ]);
}