当前位置:首页 > PHP

php实现lbs实现商品筛选

2026-03-13 02:18:38PHP

PHP 实现 LBS 商品筛选

LBS(Location-Based Service)商品筛选通常涉及根据用户地理位置筛选附近商品。以下是实现方法:

数据库设计

商品表需包含经纬度字段,例如:

php实现lbs实现商品筛选

CREATE TABLE `products` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `latitude` decimal(10,6) NOT NULL,
  `longitude` decimal(10,6) NOT NULL,
  PRIMARY KEY (`id`)
);

计算距离

使用 Haversine 公式计算两点间距离(单位:公里):

function calculateDistance($lat1, $lon1, $lat2, $lon2) {
    $earthRadius = 6371;
    $dLat = deg2rad($lat2 - $lat1);
    $dLon = deg2rad($lon2 - $lon1);
    $a = sin($dLat/2) * sin($dLat/2) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * sin($dLon/2) * sin($dLon/2);
    $c = 2 * asin(sqrt($a));
    return $earthRadius * $c;
}

MySQL 查询优化

直接使用 SQL 计算距离并筛选:

php实现lbs实现商品筛选

SELECT 
    id, 
    name, 
    (6371 * acos(cos(radians(?)) * cos(radians(latitude)) * cos(radians(longitude) - radians(?)) + sin(radians(?)) * sin(radians(latitude)))) AS distance
FROM 
    products
HAVING 
    distance < ?
ORDER BY 
    distance
LIMIT 20

Redis GEO 优化

对于高性能场景,可使用 Redis GEO 命令:

$redis->geoadd('products:geo', $longitude, $latitude, $productId);
$results = $redis->georadius('products:geo', $userLon, $userLat, $radius, 'km', ['WITHDIST']);

前端集成

获取用户位置后通过 AJAX 提交:

navigator.geolocation.getCurrentPosition(function(position) {
    $.post('/api/nearby-products', {
        lat: position.coords.latitude,
        lng: position.coords.longitude,
        radius: 5 // 5公里范围
    });
});

性能优化建议

  1. 为经纬度字段创建复合索引:INDEX(latitude, longitude)
  2. 使用存储过程预处理距离计算
  3. 对静态商品数据可预先计算网格分区
  4. 考虑使用 MongoDB 等支持地理查询的数据库

完整示例代码

// 接收前端参数
$userLat = $_POST['lat'];
$userLon = $_POST['lng'];
$radius = $_POST['radius'] ?? 5;

// 查询数据库
$stmt = $pdo->prepare("SELECT id, name, 
    (6371 * acos(cos(radians(:lat)) * cos(radians(latitude)) * 
    cos(radians(longitude) - radians(:lng)) + 
    sin(radians(:lat)) * sin(radians(latitude)))) AS distance 
    FROM products HAVING distance < :radius ORDER BY distance");

$stmt->execute([
    ':lat' => $userLat,
    ':lng' => $userLon,
    ':radius' => $radius
]);

$products = $stmt->fetchAll(PDO::FETCH_ASSOC);
header('Content-Type: application/json');
echo json_encode($products);

标签: 商品php
分享给朋友:

相关文章

php实现文件上传

php实现文件上传

PHP 文件上传实现方法 在 PHP 中实现文件上传需要处理 HTML 表单和服务器端脚本。以下是详细步骤: 创建 HTML 表单 使用 enctype="multipart/form-data"…

php 实现排序

php 实现排序

PHP 实现数组排序的方法 PHP 提供了多种内置函数和方法来实现数组排序,适用于不同的排序需求。以下是一些常见的排序实现方式: 使用 sort() 函数对数组进行升序排序 sort() 函数对数组…

php实现博客

php实现博客

使用PHP实现博客系统 数据库设计 创建数据库表存储博客文章和用户信息。常见的表包括posts(文章)和users(用户)。 CREATE TABLE users ( id INT AUTO…

php实现一个

php实现一个

PHP 实现一个简单的计算器 创建一个基本的计算器,支持加、减、乘、除运算。以下是一个完整的实现代码示例: <?php $result = ""; if ($_SERVER["REQUEST_…

php mvc 实现

php mvc 实现

PHP MVC 实现方法 MVC(Model-View-Controller)是一种设计模式,用于分离应用程序的逻辑、数据和界面。以下是实现PHP MVC框架的关键步骤。 目录结构 创建以下目录结构…

php变量的实现

php变量的实现

PHP变量的实现机制 PHP变量的实现基于Zend引擎的底层数据结构。核心结构体zval用于存储变量类型和值,其设计允许动态类型转换和高效内存管理。 zval结构体 PHP变量通过zval结构体实现…