微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – Yii 2:ActiveRecords中的虚拟字段

我使用MySQL和Yii 2.在数据库中存在表’Regions’和列’coordinates’.此列的类型是点.

sql中我可以写:
“选择X(坐标)为x,Y(坐标)为y”和“INSERT INTO区域SET坐标= 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 …()’对我没有帮助.我想避免对数据库的其他查询.

请帮我做.

解决方法:

你可以用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'
    ]);
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐