pp+mongodb 는 좌표 가 지정 한 다각형 영역 에 있 는 지 여 부 를 판단 합 니 다.

7499 단어 mongodb좌표.php
MongoDB 는 분포 식 파일 을 기반 으로 저 장 된 데이터베이스 로 지리 적 공간 을 기반 으로 하 는 색인 을 만 드 는 능력 을 제공 합 니 다.본 고 는 PHP 로 mongodb 를 연결 하여 좌표 가 지정 한 다각형 영역 에 있 는 지 여 부 를 판단 하 는 인 스 턴 스 를 제공 합 니 다.
1.다각형 영역 정의
다각형 의 좌표 점 은 다음 과 같다.
113.314882,23.163055
113.355845,23.167042
113.370289,23.149564
113.356779,23.129758
113.338238,23.13913
113.330979,23.124706
113.313588,23.140858
113.323865,23.158204
113.314882,23.163055

2.mongodb 에 데이터베이스 만 들 기

use testdb;

db.createUser( 
  { 
    "user":"root", 
    "pwd":"123456", 
    "roles":[{"role" : "readWrite", "db":"testdb"}] 
  } 
);

db.auth( 
  { 
    "user":"root", 
    "pwd":"123456" 
  } 
);

3.php 를 사용 하여 다각형 데 이 터 를 삽입 하고 좌표 가 지역 내 에 있 는 지 판단 합 니 다.
MongoDBPolygons.class.php

<?php
/**
 * MongoDB       ,             
 * Date:  2016-09-30
 * Author: fdipzone
 * Ver:  1.0
 *
 * Func:
 * public add             
 * public checkInArea               
 * private connect      mongodb
 */
class MongoDBPolygons { // class start

  // mongo db   
  private $_conn = null;

  // mongo db
  private $_db = null;

  /**
   *    
   * @param String $host  mongodb  
   * @param String $user     
   * @param String $passwd   
   * @param String $db      
   */
  public function __construct($host, $user, $passwd, $db){
    $this->_conn = $this->connect($host, $user, $passwd);
    $this->_db = $db;
  }

  /**
   *        
   * @param String $collname    
   * @param Array $data          
   * @param Array $index    
   * @return Int
   */
  public function add($collname, $data, $index){

    //     
    $cmd = array(
      'createIndexes' => $collname,
      'indexes' => array(
        array(
          'name' => 'index',
          'key' => $index,
          'ns' => $this->_db.'.'.$collname
        )
      )
    );
    $command = new MongoDB\Driver\Command($cmd);
    $this->_conn->executeCommand($this->_db, $command);

    //     
    $bulk = new MongoDB\Driver\BulkWrite();
    $inserted = 0;

    if($data){
      foreach($data as $k=>$v){
        $bulk->insert($v);
      }
      $result = $this->_conn->executeBulkWrite($this->_db.'.'.$collname, $bulk);
      $inserted = $result->getInsertedCount();
    }

    return $inserted;
  }

  /**
   *           
   * @param String $collname    
   * @param Decimal $longitude   
   * @param Decimal $latitude   
   * @return Array
   */
  public function checkInArea($collname, $longitude, $latitude){
    $filter = array(
      'polygons' => array(
          '$geoIntersects' => array(
              '$geometry' => array(
                  'type' => 'Point',
                  'coordinates' => array(doubleval($longitude), doubleval($latitude))
              )
          )
      )
    );
    $options = array('limit'=>1);
    $query = new MongoDB\Driver\Query($filter, $options);
    $cursor = $this->_conn->executeQuery($this->_db.'.'.$collname, $query);

    $result = array();
    if($cursor){
      foreach($cursor as $v){
        $result[] = $v;
      }
    }

    return $result? $result[0] : $result;
  }

  /**
   *   mongodb
   * @param String $host       
   * @param String $user     
   * @param String $passwd   
   * @return DBLink
   */
  private function connect($host, $user, $passwd){
    $server = 'mongodb://'.$user.':'.$passwd.'@'.$host;
    try{
      $conn = new MongoDB\Driver\Manager();
    } catch (MongoDB\Driver\Exception\ConnectionException $e){
      throw new ErrorException('Unable to connect to db server. Error:' . $e->getMessage(), 31);
    }
    return $conn;
  }

} // class end
?>
demo.php

<?php
require 'MongoDBPolygons.class.php';

echo '<strong>php MongoDB                :</strong><br><br>';

//   mongodb      
$oMongoDBPolygons = new MongoDBPolygons('localhost','root','123456','testdb');

//   
$index = array('polygons'=>'2dsphere');

//          
$data = array(
      array(
        'polygons' => array(
          'type' => 'Polygon',
          'coordinates' => array(
            array(
              array(doubleval(113.314882),doubleval(23.163055)),
              array(doubleval(113.355845),doubleval(23.167042)),
              array(doubleval(113.370289),doubleval(23.149564)),
              array(doubleval(113.356779),doubleval(23.129758)),
              array(doubleval(113.338238),doubleval(23.13913)),
              array(doubleval(113.330979),doubleval(23.124706)),
              array(doubleval(113.313588),doubleval(23.140858)),
              array(doubleval(113.323865),doubleval(23.158204)),
              array(doubleval(113.314882),doubleval(23.163055)),
            )
          )
        ),
      )
    );

$inserted = $oMongoDBPolygons->add('geo', $data, $index);
if($inserted){
  echo '1.         <br><br>';
}

//             
echo '2.        (113.330908, 23.155678)      <br>';
$result = $oMongoDBPolygons->checkInArea('geo', 113.330908, 23.155678);
echo '  :      (113.330908, 23.155678)'.( $result? '    ' : '    ');
echo '<br><br>';

echo '3.        (113.33831, 23.137335)      <br>';
$result = $oMongoDBPolygons->checkInArea('geo', 113.33831, 23.137335);
echo '  :      (113.33831, 23.137335)'.( $result? '    ' : '    ');
echo '<br><br>';

?>

출력:
php MongoDB 는 좌표 가 다각형 영역 에 있 는 지 판단 합 니 다.
1.다각형 데이터 삽입 성공
2.광저우 동 역 좌표(113.330908,23.155678)가 지역 내 에 있 는 지 판단
결과:광저우 동 역 좌표(113.330908,23.155678)는 지역 내 에서
3.홍 발 빌딩 좌표(113.33831,23.137335)가 지역 내 에 있 는 지 판단 한다.
결과:홍 발 빌딩 좌표(113.33831,23.137335)는 지역 외 에 있다.
광저우 동 역 좌표

홍 발 빌딩 좌표

이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기