GeoJson
对象中注册,我将其字符串化并插入具有名称“geojson”的隐藏textarea
中以便在表单内提交到服务器。问题是,我想使用PostGis
ST_GeomFromGeoJSON()
函数将此数据保存为数据库中的geometry
类型,但我无法使其正常工作。以下是目前我尝试过的方法:
$site = new Site;
$data = $request->all();
unset($data['geojson']);
foreach($data as $key=>$d)
{
$site->$key = $d;
}
$geojson = json_decode($request->geojson);
$site->save();
DB::update('update posha_sites set geom = ST_GeomFromGeoJSON(?)
WHERE num_site = ?
AND city_id = ?',
[$geojson, $request->num_site, $city_id->id]
);
目前,我正在保存所有数据,然后尝试插入地理空间
数据,因为我不知道在保存其余数据时如何使用原始查询。
这样做时,我会遇到以下错误:
无法将stdClass类的对象转换为字符串
编辑
下面是posha_sites表的完整迁移:
(注意:本翻译仅供参考,具体语言和术语应根据上下文和实际情况而定。)
public function up()
{
Schema::create('posha_sites', function (Blueprint $table) {
$table->bigIncrements('id');
$table->string('name');
$table->bigInteger('num_site');
$table->string('type', 50)->nullable();
$table->mediumText('adresse')->nullable();
$table->string('cartes_anciennes')->nullable();
$table->string('carte_topo')->nullable();
$table->mediumText('cadastre_remembre')->nullable();
$table->mediumText('cadastre_moderne')->nullable();
$table->mediumText('cadastre_ancien')->nullable();
$table->string('lieu_dit')->nullable();
$table->mediumText('nature_parcelles')->nullable();
$table->mediumText('conditions_acces')->nullable();
$table->string('situation_administrative')->nullable();
$table->string('altitude')->nullable();
$table->string('relief')->nullable();
$table->mediumText('hydrographie')->nullable();
$table->string('geologie')->nullable();
$table->string('vestiges_periode')->nullable();
$table->mediumText('vestiges_nature')->nullable();
$table->mediumText('vestiges_conservation')->nullable();
$table->longText('plans_documents_figures')->nullable();
$table->longText('sources_manuscrites')->nullable();
$table->longText('sources_imprimees')->nullable();
$table->longText('renseignement_oral')->nullable();
$table->longText('bibliographie')->nullable();
$table->longText('histoire')->nullable();
$table->longText('historiographie')->nullable();
$table->longText('description_histoire_monumentale')->nullable();
$table->geometrycollection('geom')->nullable();
$table->string('last_author')->nullable();
$table->integer('tree_id')->unsigned()->nullable();
$table->integer('parent_id')->unsigned()->nullable();
$table->integer('city_id')->unsigned();
$table->timestamps();
});
}
ST_GeomFromGeoJSON()
函数实际上需要一个字符串,所以我没有解码我的$geojson
变量:
"ST_GeomFromGeoJSON()"函数需要接收一个字符串参数,因此我没有对$geojson
变量进行解码处理:
$geojson = $request->geojson;
替代方案:
$geojson = json_decode($request->geojson);
但是我仍然遇到错误:
SQLSTATE [XX000]:内部错误:
7 ERROR:无效的GeoJson表示(SQL:update posha_sites set geom = ST_GeomFromGeoJSON({"type":“FeatureCollection”,“features”:[{"type":“Feature”,“properties”:{},“geometry”:{“type”:“Point”,“coordinates”:[-0.229114,44.564488]}}]})WHERE num_site = 248 AND city_id = 5)
但是我在在线GeoJson验证器中测试了我的geojson,看起来是正确的。
翻译结果仅供参考,如有不准确之处请以原文为准。