gpt4 book ai didi

php - MySQL SELECT 查询四舍五入到小数点后 12 位

转载 作者:行者123 更新时间:2023-11-29 07:50:25 24 4
gpt4 key购买 nike

我在 PHP 中有以下 MySQL 查询:

function queryTagsTable($tag) {
global $pdo;
$sql = "SELECT id, latitude, longitude FROM tbl WHERE id IN (SELECT id FROM `tbl_tags` WHERE tag = :tag)";
$stmt = $pdo->prepare ( $sql );
$stmt->bindValue(':tag', $tag);
if ($stmt->execute()) {
$result = $stmt->fetchAll();
foreach ($result as $row) {
echo $row['id'].', '.$row['latitude'].', '.$row['longitude'].' ';
}
}
}

在我的数据库中,等效的原始 SQL 查询有以下结果:

276     32.082504109184285  34.89628862589598

然而,我的 PHP 代码的回显似乎总是将纬度和经度结果四舍五入到小数点后 12 位,产生:

276, 32.082504109184, 34.896288625896

在我的数据库中,id 是整数,而纬度和经度是 double 。我希望 PHP 查询返回纬度和经度的完整值,以便产生最大的精度。我该怎么做才能从我的 PHP 函数接收这些结果的全部值?

最佳答案

我怀疑问题在于 MySQL 和 PHP 中的 double 有不同的精度。尝试将 double 型转换为字符串,以便 PHP 不会自动转换它们:

SELECT id, CAST(latitude AS CHAR(32)) AS latitude, CAST(longitude AS CHAR(32)) AS longitude FROM tbl WHERE id IN (SELECT id FROM `tbl_tags` WHERE tag = :tag)

关于php - MySQL SELECT 查询四舍五入到小数点后 12 位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26585802/

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