我使用 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/