php - Yii 2 : virtual fields in ActiveRecords

标签 php mysql activerecord yii2

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

在 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...()' 对我没有帮助。我想避免对数据库进行额外的查询。

请帮我做一下。

最佳答案

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

关于php - Yii 2 : virtual fields in ActiveRecords,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29344899/

相关文章:

php - TYPO3 Extbase 后端模块。模板路径问题

mysql - select 中使用聚合时,where 子句不限制记录

php - 哪个表存储wordpress帖子的缩略图地址?

php - Web 应用程序基准测试

ruby-on-rails - 无法使用 ssh 隧道和 activerecord 连接到远程数据库

ruby-on-rails - 如何在 Rails 5 中添加自定义谓词生成器?

php - 使用 htaccess 将 php 函数和一些文本添加到数百个 .htm 文件中?这行得通吗?

php - 基于用户输入的计时器 PHP

php - mkdir() 上的权限被拒绝

sql - ActiveRecord::Relation join,如何将连接表的一列添加到新名称的查询结果中?