Rumah pembangunan bahagian belakang tutorial php mongodb 地理位置搜寻

mongodb 地理位置搜寻

Aug 08, 2016 am 09:23 AM
array quot

LBS,存储每个地点的经纬度坐标,搜寻附近的地点,建立地理位置索引可提高查询效率。

mongodb地理位置索引,2d2dsphere,对应平面和球面。

1.创建lbs集合存放地点坐标

use lbs;

db.lbs.insert(
    {
        loc:{
            type: "Point",
            coordinates: [113.332264, 23.156206]
        },
        name: "广州东站"
    }
)

db.lbs.insert(
    {
        loc:{
            type: "Point",
            coordinates: [113.330611, 23.147234]
        },
        name: "林和西"
    }
)

db.lbs.insert(
    {
        loc:{
            type: "Point",
            coordinates: [113.328095, 23.165376]
        },
        name: "天平架"
    }
)
Salin selepas log masuk

2.创建地理位置索引
db.lbs.ensureIndex(
    {
        loc: "2dsphere"
    }
)
Salin selepas log masuk

3.查询附近的坐标

当前位置为:时代广场,

坐标:113.323568, 23.146436

搜寻附近一公里内的点,由近到远排序

db.lbs.find(
    {
        loc: {
            $near:{
                $geometry:{
                    type: "Point",
                    coordinates: [113.323568, 23.146436]
                },
                $maxDistance: 1000
            }
        }
    }
)
Salin selepas log masuk

搜寻结果:
{ "_id" : ObjectId("556a651996f1ac2add8928fa"), "loc" : { "type" : "Point", "coordinates" : [ 113.330611, 23.147234 ] }, "name" : "林和西" }
Salin selepas log masuk

php代码如下:
<?php // 连接mongodb
function conn($dbhost, $dbname, $dbuser, $dbpasswd){
    $server = &#39;mongodb://&#39;.$dbuser.&#39;:&#39;.$dbpasswd.&#39;@&#39;.$dbhost.&#39;/&#39;.$dbname;
    try{
        $conn = new MongoClient($server);
        $db = $conn->selectDB($dbname);
    } catch (MongoException $e){
        throw new ErrorException('Unable to connect to db server. Error:' . $e-&gt;getMessage(), 31);
    }
    return $db;
}

// 插入坐标到mongodb
function add($dbconn, $tablename, $longitude, $latitude, $name){
    $index = array('loc'=&gt;'2dsphere');
    $data = array(
            'loc' =&gt; array(
                    'type' =&gt; 'Point',
                    'coordinates' =&gt; array(doubleval($longitude), doubleval($latitude))
            ),
            'name' =&gt; $name
    );
    $coll = $dbconn-&gt;selectCollection($tablename);
    $coll-&gt;ensureIndex($index);
    $result = $coll-&gt;insert($data, array('w' =&gt; true));
    return (isset($result['ok']) &amp;&amp; !empty($result['ok'])) ? true : false;
}

// 搜寻附近的坐标
function query($dbconn, $tablename, $longitude, $latitude, $maxdistance, $limit=10){
    $param = array(
        'loc' =&gt; array(
            '$nearSphere' =&gt; array(
                '$geometry' =&gt; array(
                    'type' =&gt; 'Point',
                    'coordinates' =&gt; array(doubleval($longitude), doubleval($latitude)), 
                ),
                '$maxDistance' =&gt; $maxdistance*1000
            )
        )
    );

    $coll = $dbconn-&gt;selectCollection($tablename);
    $cursor = $coll-&gt;find($param);
    $cursor = $cursor-&gt;limit($limit);
    
    $result = array();
    foreach($cursor as $v){
        $result[] = $v;
    }  

    return $result;
}

$db = conn('localhost','lbs','root','123456');

// 随机插入100条坐标纪录
for($i=0; $i
Salin selepas log masuk

演示php代码,首先需要在mongodb的lbs中创建用户和执行auth。方法如下:

use lbs;
db.createUser(
    {
        "user":"root",
        "pwd":"123456",
        "roles":[]
    }
)

db.auth(
    {
        "user":"root",
        "pwd":"123456"
    }
)
Salin selepas log masuk

以上就介绍了mongodb 地理位置搜寻,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Isih tatasusunan menggunakan fungsi Array.Isih dalam C# Isih tatasusunan menggunakan fungsi Array.Isih dalam C# Nov 18, 2023 am 10:37 AM

Isih tatasusunan menggunakan fungsi Array.Isih dalam C#

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决

Kaedah mudah dan jelas untuk menggunakan fungsi PHP array_merge_recursive(). Kaedah mudah dan jelas untuk menggunakan fungsi PHP array_merge_recursive(). Jun 27, 2023 pm 01:48 PM

Kaedah mudah dan jelas untuk menggunakan fungsi PHP array_merge_recursive().

Cara menggunakan fungsi array_combine dalam PHP untuk menggabungkan dua tatasusunan menjadi tatasusunan bersekutu Cara menggunakan fungsi array_combine dalam PHP untuk menggabungkan dua tatasusunan menjadi tatasusunan bersekutu Jun 26, 2023 pm 01:41 PM

Cara menggunakan fungsi array_combine dalam PHP untuk menggabungkan dua tatasusunan menjadi tatasusunan bersekutu

Penjelasan terperinci tentang penggunaan fungsi PHP array_fill(). Penjelasan terperinci tentang penggunaan fungsi PHP array_fill(). Jun 27, 2023 am 08:42 AM

Penjelasan terperinci tentang penggunaan fungsi PHP array_fill().

Cara menggunakan modul Array dalam Python Cara menggunakan modul Array dalam Python May 01, 2023 am 09:13 AM

Cara menggunakan modul Array dalam Python

Apakah punca biasa ArrayStoreException di Java? Apakah punca biasa ArrayStoreException di Java? Jun 25, 2023 am 09:48 AM

Apakah punca biasa ArrayStoreException di Java?

Pengenalan kepada cara menggunakan fungsi PHP array_change_key_case(). Pengenalan kepada cara menggunakan fungsi PHP array_change_key_case(). Jun 27, 2023 am 10:43 AM

Pengenalan kepada cara menggunakan fungsi PHP array_change_key_case().

See all articles