gpt4 book ai didi

PHP/Phinx - 插入经度/纬度导致 PDO MySQL 几何对象错误

转载 作者:行者123 更新时间:2023-11-29 02:46:49 25 4
gpt4 key购买 nike

我正在尝试使用 Phinx 创建一个 CitySeeder .但是我收到以下错误:

[PDOException]                                                                                                         
SQLSTATE[22003]: Numeric value out of range: 1416 Cannot get geometry object from data you send to the GEOMETRY field

这是我的 seeders/CitySeeder.php 类。 geo_coords 字段使用 POINT 数据类型:

<?php

use Phinx\Seed\AbstractSeed;

class CitySeeder extends AbstractSeed
{
public function run()
{
$data = [
[
'name' => 'birmingham',
'geo_coords' => 'POINT(0 0)'
],
[
'name' => 'london',
'geo_coords' => 'POINT(0 0)'
],
[
'name' => 'liverpool',
'geo_coords' => 'POINT(0 0)'
],
[
'name' => 'manchester',
'geo_coords' => 'POINT(40 -100)'
],
];

$cityTable = $this->table('city');
$cityTable->insert($data)->save();
}
}

这很奇怪,因为如果我手动将其输入到数据库中,它就会起作用。

经度/纬度是否必须以某种方式格式化?我试过使用数组和空格分隔的 long lat 格式,但我仍然遇到同样的错误。我什至查看了源代码,但找不到任何有用的东西。

如有任何帮助,我们将不胜感激。

编辑

我已经检查了发生错误的 Phinx 库中的代码:

public function insert(Table $table, $row)
{
$this->startCommandTimer();
$this->writeCommand('insert', array($table->getName()));

$sql = sprintf(
"INSERT INTO %s ",
$this->quoteTableName($table->getName())
);

$columns = array_keys($row);
$sql .= "(". implode(', ', array_map(array($this, 'quoteColumnName'), $columns)) . ")";
$sql .= " VALUES (" . implode(', ', array_fill(0, count($columns), '?')) . ")";

$stmt = $this->getConnection()->prepare($sql);

$stmt->execute(array_values($row));
$this->endCommandTimer();
}

array_values($sql) 在故障点的数据是:

array(2) {
[0]=>
string(10) "birmingham"
[1]=>
string(26) "POINT(0 0)"
}

并且设置了$sql之后的查询:

string(55) "INSERT INTO `city` (`name`, `geo_coords`) VALUES (?, ?)"

prepare() 之后执行以下操作时:die(var_dump($stmt->debugDumpParams()));:

SQL: [55] INSERT INTO `city` (`name`, `geo_coords`) VALUES (?, ?)
Params: 0
NULL

记录 MySQL 查询显示如下:

2016-12-12T12:53:12.721287Z    12 Query INSERT INTO `city` (`name`, `geo_coords`) VALUES ('birmingham', 'POINT(0, 0)')

我认为这是不正确的,因为 POINT 是作为字符串插入的?

最佳答案

使用以下方法解决了问题:

<?php

use Phinx\Seed\AbstractSeed;

class CitySeeder extends AbstractSeed
{
public function run()
{
$data = [
[
'name' => 'birmingham',
'geo_coords' => [0, 0],
],
[
'name' => 'london',
'geo_coords' => [0, 0],
],
[
'name' => 'liverpool',
'geo_coords' => [0, 0],
],
[
'name' => 'manchester',
'geo_coords' => [0, 0],
],
];

$conn = $this->getAdapter()->getConnection();
$sth = $conn->prepare('INSERT INTO city (`name`, `geo_coords`) VALUES (?, POINT(?, ?))');

foreach($data as $key => $val)
{
$sth->execute([
$val['name'],
$val['geo_coords'][0],
$val['geo_coords'][1]]
);
}
}
}

关于PHP/Phinx - 插入经度/纬度导致 PDO MySQL 几何对象错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41046269/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com