티스토리 뷰

DB/MongoDB

[MongoDB] 공간 정보 인덱스

snail voyager 2023. 4. 26. 00:37
728x90
반응형

GeoJSON Object

몽고DB에서 GeoJSON Objects는 지리적 위치 정보를 나타내는 JSON 형식의 데이터입니다. GeoJSON은 다양한 지리 정보 데이터 유형을 포함하는 오픈 소스 데이터 형식으로, 지리적 위치 정보를 다루는 많은 애플리케이션에서 사용됩니다.
몽고DB는 GeoJSON Objects를 지원하며, GeoJSON 형식의 데이터를 저장하고 쿼리하기 위한 강력한 기능을 제공합니다. 모든 GeoJSON 객체는 몽고DB의 지리 공간 인덱스(Spatial Index)를 사용하여 쿼리할 수 있습니다.

  • type 필드 : GeoJSON Object 타입
    • "Point", "LineString", "Polygon", "MultiPoint", "MultiLineString", "MultiPolygon", "GeometryCollection"
  • coordinates 필드 : 위치 정보 저장
  • 내장 객체의 필드명은 GeoJSON에서 지정되므로 변경 불가
{
	"name" : "New York City",
   	 "loc" : { "type" : "Point",	//점
    		"coordinates" : [50, 2]	//경도, 위도
            }
}

{
	"name" : "Hudson River",
    	"loc" : { "type" : "LineString",		//선
    		"coordinates" : [[0,1],[0,2],[1,2]]	//점의 배열
            }
}

{
	"name" : "New England",
    	"loc" : { "type" : "Polygon",		//다각형
    		"coordinates" : [[0,1],[0,2],[1,2],[0,1]]	//점의 배열
            }
}

2dsphere

WGS84 좌표계를 기반으로 지표면을 모델링하는 구면 기하학으로 작동

지구와 같은 구에서 geometry를 계산하는 쿼리 지원

> db.openStreetMap.createIndex({"loc" : "2dsphere"})

2d

2차원 평면 상에서 geometry를 계산하는 쿼리 지원

> db.openStreetMap.createIndex({"loc" : "2d"})

6.1.1 공간 정보 쿼리 유형

"$geoIntersects" : 쿼리 위치와 교차하는 도큐먼트 조회

> db.openStreetMap.find({"loc" : 
		{"$geoIntersects" : {"$geometry" : eastVillage}}})

"$geoWithin" : 특정 지역에 완전히 포함된 항목 조회, 겹치는 지역은 반환 X

> db.openStreetMap.find({"loc" : 
		{"$geoWithin" : {"$geometry" : eastVillage}}})

"$near" : 주변 위치를 조회. 정렬을 포함하는 유일한 연산자 (거리가 가까운 곳부터 정렬)

> db.openStreetMap.find({"loc" : 
		{"$near" : {"$geometry" : eastVillage}}})

6.1.2 공간 정보 인덱스 사용

2d vs 구면 기하학

  • 인덱스 유형에 따라 구면 또는 2D 구조를 사용
  • 공간 정보 연산자가 사용하는 기하 구조 유형
  • 2d 인덱스는 구에서 평면 기하학과 거리 계산을 모두 지원 ($nearSphere를 사용)
  • 구면 기하학을 사용하는 쿼리는 2dsphere 인덱스 사용이 성능 정확성 향상
  • $geoNear 연산자는 집계 연산자
  • $near 연산자는 샤딩을 사용해 배포된 컬렉션에서는 작동 불가
  • geoNear, $geoNear 집계 연산자를 사용하려면 컬렉션에 2dsphere, 2d 인덱스가 최대 1개만 존재해야함
  • $near, $geoWithin 공간 정보 연산자는 공간 정보 인덱스 여러개 허용
  • geoNear, $geoNear 위치 필드를 포함하지 않으므로 공간 정보 인덱스 제한

왜곡

  • 구면 기하는 지도에 시각화하면 왜곡이 있는데 지구와 같은 3차원 구를 평면에 투사하는 특성 때문

데이터 탐색

> db.neighborhoods.find({name : "Clinton"})

{
	"_id" : ObjectId("55cb9c666c522cafdb053a71"),
	"geometry" : {
		"coordinates" : [
			[
				[ -73.99383108136983, 40.772931787850595 ],
				[ -73.99378736999813, 40.7729038462627 ],
				[ -73.99372534708547, 40.77286419898788 ],
				[ -73.99359086402815, 40.77279008029658 ],
				[ -73.9935026218083, 40.77275163310052 ],
				[ -73.9938744512607, 40.77223816788824 ],
				[ -73.99378189812292, 40.77219909094502 ],
				[ -73.99365606188509, 40.77214596240103 ],
				[ -73.990913074869, 40.77098775903545 ],
				[ -73.99059644681434, 40.77085481028234 ],
				[ -73.98806289548577, 40.76979080028791 ],
				[ -73.98521720327282, 40.768594630457876 ],
				[ -73.98236545039535, 40.76739215321338 ],
				[ -73.98287713521299, 40.76671559514078 ],
				[ -73.98336657834079, 40.76604524186609 ],
				[ -73.98382185703376, 40.765418474697455 ],
				[ -73.98428230080641, 40.76479181510166 ],
				[ -73.98473393779601, 40.7641691048774 ],
				[ -73.98519152159365, 40.76354367464768 ],
				[ -73.985646777246, 40.76291487498546 ],
				[ -73.98610406084957, 40.762289952604185 ],
				[ -73.98656138533342, 40.76166012236245 ],
				[ -73.98701514555319, 40.761037367477826 ],
				[ -73.98747524633461, 40.7604047868859 ],
				[ -73.98792640627741, 40.759790277157705 ],
				[ -73.98839044575146, 40.7591641866803 ],
				[ -73.98884253868641, 40.758533499560656 ],
				[ -73.98929727477788, 40.757906637649576 ],
				[ -73.98979085335512, 40.75723313191878 ],
				[ -73.99027621346482, 40.75656756555211 ],
				[ -73.99072636339712, 40.7559504055648 ],
				[ -73.99117738092271, 40.75532984908383 ],
				[ -73.99163271310638, 40.754706805009576 ],
				[ -73.99446824672701, 40.755908862204656 ],
				[ -73.9950060160212, 40.7561367143702 ],
				[ -73.99511286348468, 40.7561757739435 ],
				[ -73.99577488185152, 40.756454515229386 ],
				[ -73.99729876461934, 40.75710704073588 ],
				[ -73.9972337372397, 40.757209542780984 ],
				[ -73.9969217787116, 40.75763758169518 ],
				[ -73.9968524487864, 40.75773270941386 ],
				[ -73.99680089701198, 40.75778916020664 ],
				[ -73.99663529266019, 40.758012921859695 ],
				[ -73.996409415542, 40.758339158674424 ],
				[ -73.99594236631536, 40.75898097909526 ],
				[ -73.99547450100974, 40.75962685701749 ],
				[ -73.9962322314278, 40.75994603212295 ],
				[ -73.99831474421812, 40.76082320924071 ],
				[ -74.00103587459182, 40.761968352259274 ],
				[ -74.00115054116876, 40.76202581235694 ],
				[ -74.00127796266635, 40.76207582517443 ],
				[ -74.00133748538708, 40.76220852185866 ],
				[ -74.00153309066982, 40.762644598630146 ],
				[ -74.00375735037694, 40.76358224164055 ],
				[ -74.00361214794175, 40.7637770439097 ],
				[ -74.001386036986, 40.76285009500187 ],
				[ -74.00097308022016, 40.76342027172565 ],
				[ -74.0031497698899, 40.76433288818462 ],
				[ -74.00294809515722, 40.7646168359313 ],
				[ -74.00306161234066, 40.76466578265341 ],
				[ -74.00313458336224, 40.76464959820669 ],
				[ -74.00316194577044, 40.764612610454606 ],
				[ -74.00322275585361, 40.7646380376702 ],
				[ -74.00315587058184, 40.764730509879946 ],
				[ -74.00314652967029, 40.76473628138698 ],
				[ -74.00313606019564, 40.76474079643811 ],
				[ -74.00312475154765, 40.76474393023147 ],
				[ -74.00311291631208, 40.764745596144905 ],
				[ -74.00310088163035, 40.76474574813035 ],
				[ -74.0030889801569, 40.764744381986745 ],
				[ -74.00106364220511, 40.76388820826285 ],
				[ -74.00073105253732, 40.763755285858814 ],
				[ -73.9999271236773, 40.763406528479315 ],
				[ -73.99963853555371, 40.76356907099077 ],
				[ -73.99962263458187, 40.763559081210445 ],
				[ -73.99951767096823, 40.76370627918026 ],
				[ -73.99944642217315, 40.76380619457846 ],
				[ -73.99943330724618, 40.76382391019697 ],
				[ -73.99915098087908, 40.76420525958269 ],
				[ -74.00227436642373, 40.76552518109954 ],
				[ -74.00228802371481, 40.765561543795194 ],
				[ -74.00205713831564, 40.76587739041858 ],
				[ -74.00202454330334, 40.76589326657037 ],
				[ -73.99919997246741, 40.76470191498249 ],
				[ -73.99910832564545, 40.764662499354934 ],
				[ -73.99888473174988, 40.76456937704849 ],
				[ -73.99857638530538, 40.76499860727076 ],
				[ -73.99859978707624, 40.76507334028592 ],
				[ -73.99863487876343, 40.76508579473773 ],
				[ -73.99866530473442, 40.76510448074716 ],
				[ -73.99868637477218, 40.765137394267725 ],
				[ -73.998695730373, 40.76517476567954 ],
				[ -73.99868870694561, 40.76520856994725 ],
				[ -73.99866764711376, 40.7652370353429 ],
				[ -73.99863371556071, 40.76526016874121 ],
				[ -73.99858924105146, 40.76527617880681 ],
				[ -73.99848276468683, 40.76529753698438 ],
				[ -73.99843830371465, 40.76531621383384 ],
				[ -73.99840202518251, 40.76535090908752 ],
				[ -73.99835829733873, 40.76541804876374 ],
				[ -73.99829119846427, 40.76552107275873 ],
				[ -73.9982709030835, 40.76555223341324 ],
				[ -73.9982816070953, 40.765567774934745 ],
				[ -74.00154217871201, 40.766944702532655 ],
				[ -74.00157335385266, 40.766977192210675 ],
				[ -74.0015618057548, 40.76699649936827 ],
				[ -74.00139437159498, 40.767230047733 ],
				[ -74.00136434612979, 40.76724936397109 ],
				[ -74.00131469636003, 40.76725111954735 ],
				[ -74.00129391014994, 40.76724145824157 ],
				[ -73.9981567843898, 40.76589403537407 ],
				[ -73.99814818647366, 40.76590560707494 ],
				[ -73.99806675905354, 40.76587188113569 ],
				[ -73.99772134825697, 40.76634912055574 ],
				[ -73.99737808447965, 40.766823385876954 ],
				[ -74.00062837395305, 40.76820311105869 ],
				[ -74.000650167862, 40.76822037378663 ],
				[ -74.00064950530418, 40.76824523610554 ],
				[ -74.00045489336716, 40.76850419517742 ],
				[ -74.00041765393195, 40.76851247996441 ],
				[ -74.00038586489076, 40.76850419542928 ],
				[ -73.9971558894921, 40.767128696172776 ],
				[ -73.99681598463503, 40.76760062185914 ],
				[ -73.9964571540504, 40.76809881579561 ],
				[ -73.999728191901, 40.76947350663367 ],
				[ -73.99973590247853, 40.769506177331515 ],
				[ -73.99955518930786, 40.76975080774004 ],
				[ -73.99951552161613, 40.769767565837796 ],
				[ -73.99947253734022, 40.76976421496913 ],
				[ -73.9970717603931, 40.76873264357683 ],
				[ -73.99702628821072, 40.768795515623836 ],
				[ -73.99715035477146, 40.768847387713386 ],
				[ -73.99701071413826, 40.76902879065362 ],
				[ -73.9968931131237, 40.76897962881942 ],
				[ -73.99657126439575, 40.76942456827381 ],
				[ -73.99902682832904, 40.77046327298205 ],
				[ -73.99876206914314, 40.77082505670919 ],
				[ -73.99631327022087, 40.769798836336406 ],
				[ -73.99588004351688, 40.77040057901223 ],
				[ -73.99601693196198, 40.77045484888617 ],
				[ -73.99590077425033, 40.77061312350094 ],
				[ -73.99576733283618, 40.77055459595386 ],
				[ -73.99542474436304, 40.77103161516794 ],
				[ -73.99575648212901, 40.771160668465775 ],
				[ -73.99570859069948, 40.77122581253292 ],
				[ -73.99579774020454, 40.77128256276406 ],
				[ -73.99581687579042, 40.771256516415534 ],
				[ -73.99591283603844, 40.77129785562375 ],
				[ -73.99592803670673, 40.771275102837606 ],
				[ -73.9960017574905, 40.77130746533053 ],
				[ -73.99589990100937, 40.77145029858208 ],
				[ -73.99589260894888, 40.771447087024605 ],
				[ -73.9958543725281, 40.771499180748435 ],
				[ -73.9957911774878, 40.77147551882039 ],
				[ -73.99582805886243, 40.7714216672224 ],
				[ -73.99572993314408, 40.77137881879371 ],
				[ -73.99575123412826, 40.7713542822772 ],
				[ -73.99562982240307, 40.77132529262805 ],
				[ -73.99562306904365, 40.77133695751284 ],
				[ -73.99530566365357, 40.7711960049095 ],
				[ -73.99512395556886, 40.77145073826707 ],
				[ -73.99499014482075, 40.77144070980646 ],
				[ -73.99495733353699, 40.77144919069768 ],
				[ -73.9949350165901, 40.7714681460754 ],
				[ -73.9949238579442, 40.77148560543488 ],
				[ -73.99492582120637, 40.77151604240547 ],
				[ -73.99500915438729, 40.77160733944154 ],
				[ -73.99497830771197, 40.77164524947327 ],
				[ -73.99497688494729, 40.77165877492331 ],
				[ -73.99711218538607, 40.77255323669951 ],
				[ -73.99690946902787, 40.77283294565994 ],
				[ -73.99477407930821, 40.771929547530185 ],
				[ -73.99444501293384, 40.77237712658829 ],
				[ -73.99545514995589, 40.77280267502907 ],
				[ -73.99554492520852, 40.77267481382617 ],
				[ -73.99644894667634, 40.77305684199672 ],
				[ -73.99635558854989, 40.77317889165249 ],
				[ -73.99622972001937, 40.773128974542715 ],
				[ -73.99614329133081, 40.77324754156346 ],
				[ -73.9965615947765, 40.773410941448425 ],
				[ -73.99668544431167, 40.77350368804624 ],
				[ -73.99667705784742, 40.77351005394216 ],
				[ -73.99434191991621, 40.77252478194341 ],
				[ -73.99424979228651, 40.77252648513809 ],
				[ -73.99416328456306, 40.77248719102126 ],
				[ -73.99383108136983, 40.772931787850595 ]
			]
		],
		"type" : "Polygon"
	},
	"name" : "Clinton"
}

> db.restaurants.find({name : "Little Pie Company"})

{
	"_id" : ObjectId("55cba2476c522cafdb053dea"),
	"location" : {
		"coordinates" : [ -73.99331699999999, 40.7594404 ],
		"type" : "Point"
	},
	"name" : "Little Pie Company"
}

현재 지역 찾기

정확한 위치 정보를 제공한다고 가정할 때 $geoIntersects를 사용해 조회

> db.neighborhoods.findOne({geometry : {$geoIntersects : {$geometry: {type:"Point", coordinates:[-73.93414657,40.82302903]}}}})

{
	"_id" : ObjectId("55cb9c666c522cafdb053a68"),
	"geometry" : {
		"coordinates" : [
			[
				[ -73.93383000695911, 40.81949109558767 ],
				[ -73.93411701695138, 40.81955053491088 ],
				[ -73.93431276819767, 40.81962986684897 ],
				[ -73.93440040009484, 40.819667782434465 ],
				[ -73.93439036753757, 40.81958743539698 ],
				[ -73.93438112852347, 40.81932807562949 ],
				[ -73.9342948780807, 40.81890498677685 ],
				[ -73.93423576072603, 40.818649319251364 ],
				[ -73.93408482013453, 40.81793086150489 ],
				[ -73.9340746397773, 40.81782651394852 ],
				[ -73.93412816761214, 40.8177339625139 ],
				[ -73.93423519549512, 40.81755488121525 ],
				[ -73.93445400138874, 40.81718852906137 ],
				[ -73.93463790272767, 40.81690804797262 ],
				[ -73.93487343834981, 40.8165278475176 ],
				[ -73.93575548210782, 40.81532558429708 ],
				[ -73.93613554330996, 40.8147881266393 ],
				[ -73.93620957748075, 40.81467385042275 ],
				[ -73.93668854882762, 40.81404163072326 ],
				[ -73.93708163694987, 40.81350614105259 ],
				[ -73.93714398424214, 40.81342104144455 ],
				[ -73.93761714951756, 40.81274036483138 ],
				[ -73.93813552407511, 40.812065619232335 ],
				[ -73.93820642688317, 40.81196760479798 ],
				[ -73.93830925043022, 40.81182546401121 ],
				[ -73.93838748529838, 40.81171844357887 ],
				[ -73.93863753326706, 40.81137638806709 ],
				[ -73.93874394437573, 40.811230820566436 ],
				[ -73.93901753314599, 40.810856556874455 ],
				[ -73.93740733660461, 40.810175611401206 ],
				[ -73.93580780201182, 40.80949763825762 ],
				[ -73.93586263420018, 40.80943020292132 ],
				[ -73.93625936035667, 40.808855608725686 ],
				[ -73.93671827467928, 40.80822047872675 ],
				[ -73.93718011799034, 40.80759900035796 ],
				[ -73.93763439424364, 40.806974606921834 ],
				[ -73.93808666916728, 40.80635301191095 ],
				[ -73.93854407929403, 40.805729652932854 ],
				[ -73.93869430486176, 40.80579102921082 ],
				[ -73.94015793743944, 40.80640908964353 ],
				[ -73.94177140170032, 40.807089000349656 ],
				[ -73.94491601785558, 40.80841350378125 ],
				[ -73.94499360671229, 40.80844618384186 ],
				[ -73.94506102986607, 40.8084745003499 ],
				[ -73.94773985453432, 40.80959972161701 ],
				[ -73.94783892229975, 40.8096411278052 ],
				[ -73.9479230680906, 40.809676922465236 ],
				[ -73.95067975515929, 40.81084296435352 ],
				[ -73.95210125149222, 40.81144285350124 ],
				[ -73.95150537264615, 40.81200768463676 ],
				[ -73.95098203327805, 40.81252162978943 ],
				[ -73.95092865672767, 40.81257507153118 ],
				[ -73.95035019142966, 40.81315938878694 ],
				[ -73.94986218985588, 40.81379998043675 ],
				[ -73.94962668076091, 40.81410004983843 ],
				[ -73.94962653685337, 40.81410023874317 ],
				[ -73.94962639580584, 40.81410043619291 ],
				[ -73.94940550546026, 40.814407409502984 ],
				[ -73.9491996001398, 40.81472085408311 ],
				[ -73.94900927796705, 40.815039942538704 ],
				[ -73.9488349125204, 40.81536398055535 ],
				[ -73.94867681741437, 40.81569228551455 ],
				[ -73.94835601519225, 40.816374305618886 ],
				[ -73.94800732867309, 40.8171165088993 ],
				[ -73.94766641252582, 40.817855509489 ],
				[ -73.94734953979686, 40.81853499822355 ],
				[ -73.94703623206819, 40.81920837200807 ],
				[ -73.94671832033764, 40.81989426803384 ],
				[ -73.9464028984772, 40.82057204218477 ],
				[ -73.94607828674226, 40.82126321606192 ],
				[ -73.94516004895775, 40.82087904397888 ],
				[ -73.94460364603806, 40.82146198118819 ],
				[ -73.9440498636813, 40.822051592105 ],
				[ -73.94350594463333, 40.82262775327937 ],
				[ -73.94292366912582, 40.82326058725043 ],
				[ -73.9424295395631, 40.823909156935464 ],
				[ -73.94195569728996, 40.82455444012053 ],
				[ -73.9415031265368, 40.82517136689069 ],
				[ -73.94104840809351, 40.8257926296038 ],
				[ -73.94059472654726, 40.82641360402922 ],
				[ -73.94013953822807, 40.82703869055559 ],
				[ -73.9396895279914, 40.827656574227866 ],
				[ -73.93924885616293, 40.828296351211876 ],
				[ -73.93896034889055, 40.82898632996019 ],
				[ -73.93864026693868, 40.82973887442052 ],
				[ -73.93899743437669, 40.82988885286428 ],
				[ -73.93943428772432, 40.83007611669215 ],
				[ -73.93962569930143, 40.83015583738796 ],
				[ -73.94017089788652, 40.83038439112869 ],
				[ -73.94007905795213, 40.83046395774134 ],
				[ -73.93998939894344, 40.83073096688919 ],
				[ -73.93996368656906, 40.83082053430401 ],
				[ -73.93996366268432, 40.83082060632692 ],
				[ -73.9399239511922, 40.83090806016343 ],
				[ -73.93992389241943, 40.830908177064586 ],
				[ -73.93992383233875, 40.8309082768776 ],
				[ -73.93987063346383, 40.83099179606697 ],
				[ -73.93987057339177, 40.83099188616358 ],
				[ -73.93987049016128, 40.83099197658315 ],
				[ -73.9398049898395, 40.831069790159276 ],
				[ -73.93980484742822, 40.831069960289355 ],
				[ -73.93980468099204, 40.83107011331944 ],
				[ -73.93972831443872, 40.831140898571746 ],
				[ -73.9396098257029, 40.83125089467677 ],
				[ -73.93960970782902, 40.831251002332976 ],
				[ -73.93960960075394, 40.83125111920869 ],
				[ -73.93950338652492, 40.831369460472445 ],
				[ -73.9394108340693, 40.83149499458965 ],
				[ -73.93941078701702, 40.83149507581406 ],
				[ -73.93933313154191, 40.83162629993882 ],
				[ -73.93927119324165, 40.8317616573971 ],
				[ -73.93927116936439, 40.8317617200385 ],
				[ -73.93927114613948, 40.8317617928992 ],
				[ -73.93922536460632, 40.83189966097508 ],
				[ -73.93913480796968, 40.83209759542905 ],
				[ -73.93902897268019, 40.83229149797039 ],
				[ -73.93894859789032, 40.832417335825774 ],
				[ -73.9389083447814, 40.8324803571376 ],
				[ -73.93877360195538, 40.83266321215949 ],
				[ -73.93868316230177, 40.83280078941747 ],
				[ -73.93862894892672, 40.83285794170846 ],
				[ -73.93857474693523, 40.83291508577085 ],
				[ -73.93838508900461, 40.83311350252125 ],
				[ -73.93795718243024, 40.83345441842215 ],
				[ -73.93729719818138, 40.83397732122566 ],
				[ -73.93729666512158, 40.833977744101354 ],
				[ -73.93705905884407, 40.834165988650966 ],
				[ -73.93700641578684, 40.83419311017997 ],
				[ -73.93649557128383, 40.83456879562555 ],
				[ -73.93572624332147, 40.835156346599724 ],
				[ -73.93530788003893, 40.83547772443074 ],
				[ -73.93506336342621, 40.835677658809985 ],
				[ -73.93496274110689, 40.83575993474983 ],
				[ -73.93485740276071, 40.83598502557723 ],
				[ -73.93479886277844, 40.83611011575883 ],
				[ -73.93474569422972, 40.83609209412601 ],
				[ -73.93467393068329, 40.8360649032391 ],
				[ -73.93460027698636, 40.836096868110225 ],
				[ -73.93436132705641, 40.836200775593426 ],
				[ -73.93445239397373, 40.83598096014986 ],
				[ -73.93456051826973, 40.83586608172802 ],
				[ -73.9347546645066, 40.83558929983925 ],
				[ -73.93475368707841, 40.835569821114206 ],
				[ -73.93480514039258, 40.835427472645954 ],
				[ -73.93481898168221, 40.83539825039465 ],
				[ -73.93483181137555, 40.83538552549233 ],
				[ -73.93484813571963, 40.83535143220732 ],
				[ -73.93486985067804, 40.835332715131045 ],
				[ -73.93489460041994, 40.83525404312231 ],
				[ -73.9349153357865, 40.83523082193877 ],
				[ -73.93493620828455, 40.83508021765152 ],
				[ -73.93494225855345, 40.83502687541725 ],
				[ -73.93495859566971, 40.834882778542124 ],
				[ -73.93497941208676, 40.83478912095097 ],
				[ -73.93498833140738, 40.83474865739103 ],
				[ -73.9349508717846, 40.83470667336766 ],
				[ -73.93495775984087, 40.83468276036334 ],
				[ -73.9349652301556, 40.83465684795367 ],
				[ -73.93496624164193, 40.83462912314566 ],
				[ -73.93497316061229, 40.83462163453901 ],
				[ -73.93497219073575, 40.834608144294975 ],
				[ -73.9349938973671, 40.83459766568047 ],
				[ -73.9350306032399, 40.83439236534125 ],
				[ -73.93503612427712, 40.83429832034331 ],
				[ -73.9350312411865, 40.8342488623469 ],
				[ -73.93504212490855, 40.83421139923443 ],
				[ -73.93507644502898, 40.83392404328705 ],
				[ -73.93506958098244, 40.83388731750217 ],
				[ -73.93508341363373, 40.8338655969296 ],
				[ -73.93509687471908, 40.83371535679221 ],
				[ -73.93509690469142, 40.83368463190984 ],
				[ -73.93510384255589, 40.83365765691782 ],
				[ -73.93511245100076, 40.83342573907345 ],
				[ -73.9351174304809, 40.83337703428137 ],
				[ -73.93512041704275, 40.83335380306745 ],
				[ -73.93513225848743, 40.83334482290499 ],
				[ -73.93512636041868, 40.833326080356244 ],
				[ -73.93512935500891, 40.83329460947993 ],
				[ -73.93512443552862, 40.833281118185184 ],
				[ -73.93513826819081, 40.83326014375564 ],
				[ -73.93513729127852, 40.83324141318857 ],
				[ -73.9351304030063, 40.833228667273474 ],
				[ -73.93512154973723, 40.83320169227403 ],
				[ -73.93512352949863, 40.83318969900627 ],
				[ -73.93511565892307, 40.83317620538069 ],
				[ -73.93513243602689, 40.83316272511775 ],
				[ -73.93513935847737, 40.83315149100031 ],
				[ -73.93512752379405, 40.833142488809095 ],
				[ -73.93512465984577, 40.833051069029295 ],
				[ -73.93512171853354, 40.83302859034757 ],
				[ -73.93511580946038, 40.83302184217288 ],
				[ -73.93511187882301, 40.833003100729215 ],
				[ -73.9351197936552, 40.832983628174176 ],
				[ -73.93511783020568, 40.83296713902448 ],
				[ -73.93512376770083, 40.832945412996715 ],
				[ -73.93512085547363, 40.83290419576848 ],
				[ -73.93513170518374, 40.832902697673674 ],
				[ -73.93514455114399, 40.83288472203649 ],
				[ -73.93516725294636, 40.83287499227589 ],
				[ -73.9351648084094, 40.832852883264245 ],
				[ -73.93515659173381, 40.83268240623723 ],
				[ -73.93512878131627, 40.83236353447687 ],
				[ -73.93511398341515, 40.83236577683714 ],
				[ -73.9350778924617, 40.83194162361134 ],
				[ -73.9350956518488, 40.83194238126701 ],
				[ -73.93508783728588, 40.83185919835 ],
				[ -73.93506824974105, 40.83170406762572 ],
				[ -73.93502275465515, 40.83131999954984 ],
				[ -73.93498505621454, 40.83102735335791 ],
				[ -73.93493515655048, 40.83060244471323 ],
				[ -73.93489353332376, 40.83028656383774 ],
				[ -73.9348308720848, 40.82980843705177 ],
				[ -73.93479881905735, 40.82979230914966 ],
				[ -73.93480080676932, 40.82977283325497 ],
				[ -73.93478996278796, 40.82976832407672 ],
				[ -73.93479293827903, 40.829756340752134 ],
				[ -73.93478111085824, 40.82974059316723 ],
				[ -73.93477028229691, 40.829720361694214 ],
				[ -73.93475944294427, 40.82970012100015 ],
				[ -73.93476343288322, 40.82965740394856 ],
				[ -73.93474372591281, 40.82963716812013 ],
				[ -73.93473930830996, 40.82960906094397 ],
				[ -73.93474919492779, 40.82959708136339 ],
				[ -73.93473737349919, 40.82957458942519 ],
				[ -73.93472260127821, 40.82955060049557 ],
				[ -73.93472557699927, 40.82952736927084 ],
				[ -73.93471476025762, 40.82949514407967 ],
				[ -73.93470100252415, 40.82944043079997 ],
				[ -73.93469412707415, 40.829416455216 ],
				[ -73.93471288560723, 40.829400725442056 ],
				[ -73.93470504902284, 40.8293407746905 ],
				[ -73.93469321669619, 40.829328773601276 ],
				[ -73.93467597101815, 40.82931340221048 ],
				[ -73.93466228987832, 40.82918075994599 ],
				[ -73.93468302702506, 40.829165787333515 ],
				[ -73.9347076940248, 40.82915830979219 ],
				[ -73.93470080780772, 40.829132073631314 ],
				[ -73.93468107924859, 40.82913355777876 ],
				[ -73.93467714880202, 40.82911632854787 ],
				[ -73.93467025222027, 40.829112570426375 ],
				[ -73.9346544761815, 40.82909757696104 ],
				[ -73.93464959243246, 40.829048119407005 ],
				[ -73.93466193198351, 40.82903876029445 ],
				[ -73.93466295225605, 40.82901403331146 ],
				[ -73.93466495971361, 40.82897356682647 ],
				[ -73.9346561102258, 40.8289428363861 ],
				[ -73.93465515536505, 40.82891285858107 ],
				[ -73.93463641852125, 40.828906860149004 ],
				[ -73.93461640343895, 40.82869365579327 ],
				[ -73.93461171264785, 40.82868983525941 ],
				[ -73.9346026032382, 40.8286824012377 ],
				[ -73.93460883576688, 40.82866118868208 ],
				[ -73.93461052506919, 40.82865543568963 ],
				[ -73.93460804993306, 40.82865336301816 ],
				[ -73.93460065845316, 40.82864718221304 ],
				[ -73.93459873640631, 40.82860072400893 ],
				[ -73.9346019211835, 40.82859254929859 ],
				[ -73.93461159553205, 40.82856775518616 ],
				[ -73.9346091744548, 40.82852167496809 ],
				[ -73.93461017716513, 40.828502936290164 ],
				[ -73.93461219001, 40.828457229149016 ],
				[ -73.93460433489886, 40.82842800279464 ],
				[ -73.9346073136309, 40.828401025563686 ],
				[ -73.93460043185587, 40.828382282414324 ],
				[ -73.93460834555331, 40.82836355753896 ],
				[ -73.93459750565475, 40.82834482035352 ],
				[ -73.93460048488119, 40.828328333985056 ],
				[ -73.93459360040842, 40.82830135116008 ],
				[ -73.93458674147796, 40.82825938499242 ],
				[ -73.93459562914447, 40.82825114985731 ],
				[ -73.93458676210544, 40.828238402776456 ],
				[ -73.9345917047489, 40.82822716755982 ],
				[ -73.9345976397154, 40.82820843167847 ],
				[ -73.93458877267295, 40.828195693476445 ],
				[ -73.93458684240801, 40.828156719068794 ],
				[ -73.93456513010248, 40.828162704449355 ],
				[ -73.93455810179866, 40.82811740277772 ],
				[ -73.93454586266017, 40.82804816146416 ],
				[ -73.93454230638145, 40.82802687031302 ],
				[ -73.93453258880567, 40.82796855836172 ],
				[ -73.93452175638055, 40.82790780009134 ],
				[ -73.93453898134064, 40.827903472670705 ],
				[ -73.93453183092765, 40.82784940204341 ],
				[ -73.93452076528119, 40.827765689650995 ],
				[ -73.93451590672417, 40.82772893075845 ],
				[ -73.9344239633905, 40.82704289397212 ],
				[ -73.93448291058759, 40.82703709277874 ],
				[ -73.93446426549492, 40.826842205193444 ],
				[ -73.93442844400516, 40.82646785059142 ],
				[ -73.93436717955377, 40.82582759815849 ],
				[ -73.93435643452149, 40.82582093714432 ],
				[ -73.93432574289122, 40.82523259029442 ],
				[ -73.93429530732776, 40.824649231222764 ],
				[ -73.93429371670614, 40.82449638641463 ],
				[ -73.93427285440853, 40.82443895275131 ],
				[ -73.93424642895086, 40.82416688303718 ],
				[ -73.93421834803296, 40.8237990457901 ],
				[ -73.93416594530659, 40.82307858087094 ],
				[ -73.93414657666992, 40.82302903205041 ],
				[ -73.93414604382139, 40.82302061918035 ],
				[ -73.93413373625339, 40.82280065597678 ],
				[ -73.93412126165074, 40.822647252741696 ],
				[ -73.93411752612663, 40.82252433268843 ],
				[ -73.9341023336635, 40.82220121691671 ],
				[ -73.9340998673827, 40.8221399123411 ],
				[ -73.93409843799961, 40.822104227343814 ],
				[ -73.9340911251742, 40.82199603748752 ],
				[ -73.93407944723481, 40.82180557579623 ],
				[ -73.93407434354855, 40.82171709911024 ],
				[ -73.93407734095156, 40.82169456177001 ],
				[ -73.93407005522697, 40.82155932093417 ],
				[ -73.93404447476466, 40.82117670357437 ],
				[ -73.93404599779085, 40.82113387652021 ],
				[ -73.93403560443227, 40.82095254677987 ],
				[ -73.93402662334586, 40.820816809752856 ],
				[ -73.93400389615744, 40.820397839681526 ],
				[ -73.93400069207455, 40.82033819717466 ],
				[ -73.93398295705481, 40.8199999202017 ],
				[ -73.93398664640615, 40.819968034725136 ],
				[ -73.93397241531086, 40.819729574765596 ],
				[ -73.93383009163725, 40.81971974292704 ],
				[ -73.9338307684026, 40.81959665747723 ],
				[ -73.93383000695911, 40.81949109558767 ]
			]
		],
		"type" : "Polygon"
	},
	"name" : "Central Harlem North-Polo Grounds"
}

지역 내 모든 레스토랑 찾기

> var neighborhood = db.neighborhoods.findOne({
    geometry: {
        $geoIntersects : {
            $geometry: {
                type : "Point",
                coordinates : [-73.93414657,40.82302903]
            }
        }
    }
});

> db.restaurants.find({
    location : {
        $geoWithin : {
            $geometry : neighborhood.geometry
        }
    }
}, {name:1, _id:0});

/* 1 */
{
	"name" : "Perfect Taste"
},

/* 2 */
{
	"name" : "Event Productions Catering & Food Services"
},

/* 3 */
{
	"name" : "Sylvia'S Restaurant"
},

/* 4 */
{
	"name" : "Corner Social"
},

/* 5 */
{
	"name" : "Cove Lounge"
},

/* 6 */
{
	"name" : "Manna'S Restaurant"
},

/* 7 */
{
	"name" : "Harlem Bar-B-Q"
},

/* 8 */
{
	"name" : "Hong Cheong"
},

/* 9 */
{
	"name" : "Lighthouse Fishmarket"
},

/* 10 */
{
	"name" : "Mahalaxmi Food Inc"
},

/* 11 */
{
	"name" : "Rose Seeds"
},

/* 12 */
{
	"name" : "J. Restaurant"
},

/* 13 */
{
	"name" : "Harlem Coral Llc"
},

/* 14 */
{
	"name" : "Baraka Buffet"
},

/* 15 */
{
	"name" : "Make My Cake"
},

/* 16 */
{
	"name" : "Hyacinth Haven Harlem"
},

/* 17 */
{
	"name" : "Mcdonald'S"
},

/* 18 */
{
	"name" : "Ihop"
},

/* 19 */
{
	"name" : "Island Spice And Southern Cuisine"
},

/* 20 */
{
	"name" : "To Your Health & Happiness"
},

/* 21 */
{
	"name" : "Cafe 22"
},

/* 22 */
{
	"name" : "Popeyes Chicken & Biscuits"
},

/* 23 */
{
	"name" : "Herbalife"
},

/* 24 */
{
	"name" : "Elsie'S Caribbean Cafe"
},

/* 25 */
{
	"name" : "Shrine/Yatenga"
},

/* 26 */
{
	"name" : "Little Harlem Fried Chicken"
},

/* 27 */
{
	"name" : "Acts 3 Bagels"
},

/* 28 */
{
	"name" : "Uptown Slices"
},

/* 29 */
{
	"name" : "Abyssinia Ethiopian Restaurant"
},

/* 30 */
{
	"name" : "New Crispy Bamboo"
},

/* 31 */
{
	"name" : "Lil Bite'S Cafe"
},

/* 32 */
{
	"name" : "Yvonne Yvonne Restaurant"
},

/* 33 */
{
	"name" : "Subway"
},

/* 34 */
{
	"name" : "Ma Dukes"
},

/* 35 */
{
	"name" : "American Legion Veterans Post"
},

/* 36 */
{
	"name" : "Keur Sokhna Restaurant"
},

/* 37 */
{
	"name" : "Great Wall Kitchen"
},

/* 38 */
{
	"name" : "Harlem Karibe Take Out"
},

/* 39 */
{
	"name" : "Oui, Oui, Crepes And Pizza"
},

/* 40 */
{
	"name" : "White Castle"
},

/* 41 */
{
	"name" : "New Ocean"
},

/* 42 */
{
	"name" : "Jacob Soul Food Restaurant"
},

/* 43 */
{
	"name" : "Jimbo'S Hamburgers"
},

/* 44 */
{
	"name" : "Lenox Saphire"
},

/* 45 */
{
	"name" : "Subway"
},

/* 46 */
{
	"name" : "Lenox Coffee"
},

/* 47 */
{
	"name" : "Manna Restaurant Ii"
},

/* 48 */
{
	"name" : "Golden Krust Caribbean Bakery & Grill"
},

/* 49 */
{
	"name" : "Island Salad"
},

/* 50 */
{
	"name" : "China Wok"
}

범위 내에서 레스토랑 찾기

  • 원형 지역 내 탐색 $centerSphere 와 함께 $geoWithin을 사용
  • 정렬되지 않은 순서로 반환
  • $centerSphere는 중심과 반경을 radian으로 지정해 원형 영역을 나타내는 구문
  • $maxDistance 와 $nearSphere 사용하면 거리 순으로 정렬된 결과 반환
> db.restaurants.find({
    location : {
        $geoWithin : {
            $centerSphere: [
                [-73.93414657, 40.82302903], 5/3963.2]	//5마일 이내 레스토랑 탐색
        }
    }
});

var METERS_PER_MILE = 1609.34;
db.restaurants.find({
    location : {
        $nearSphere : {
            $geometry: {
                type : "Point",
                coordinates : [-73.93414657, 40.82302903]
            },
            $maxDistance : 5 * METERS_PER_MILE	//미터 단위로 변환
        }
    }
});

6.1.3 복합 공간 정보 인덱스

  • 다른 인덱스와 마찬가지로 다른 필드와 묶어서 복잡한 쿼리 최적화
  • 첫 번째 인덱스 조건으로 결과를 더 많이 필터링 가능하도록 구성
db.openStreetMap.createIndex({"tags": 1, "location" : "2sphere"})

db.openStreetMap.find({"loc" : {"$geoWithin" :
    {"$geometry" : hellsKitchen.geometry}},
    "tags" : "pizza"})

6.1.4 2d 인덱스

  • 비구체 지도에는 "2dsphere" 대신 "2d" 인덱스 사용
  • 지형이 구체가 아니라 완전히 평평한 표면이라고 가정
  • 극 주변은 왜곡이 매우 심하므로 사용하면 안됨
  • 인덱스 필드에 요소가 2개인 배열 사용, 경도와 위도
  • 점만 인덱싱할 수 있기 때문에 GeoJSON 데이터 저장하지 말자
  • 기본적으로 -180과 180 사이에 있다고 가정. 범위 조정 가능
db.hyrule.createIndex("light-years" : "2d"}, {"min" : -1000, "max": 1000})
  • $geoWithin 평평한 표면에 정의된 영역 내 점을 쿼리하는데 사용
db.hyrule.find({"title" : {
    $geoWithin : {
        $box : [[10, 10], [100], [100]]
    }
}})
  • $near 는 주변에 있는 점을 쿼리
  • 특정 지점으로부터 가장 가까운 좌표 쌍을 포함하는 도큐먼트를 반환
  • 거리가 가까운 순으로 정렬
  • 제한이 지정되지 않으면 기본적으로 100개 제한
db.hyrule.find({"title" : { $near : [20,21]}})

db.hyrule.find({"title" : { $near : [20,21]}}).limit(10)

 

 

 

https://www.mongodb.com/docs/manual/geospatial-queries/

 

728x90
반응형

'DB > MongoDB' 카테고리의 다른 글

[MongoDB] 애플리케이션 설계  (0) 2023.06.20
[MongoDB] 집계 프레임워크  (0) 2023.05.10
[MongoDB] 인덱싱2  (0) 2023.04.18
[MongoDB] 인덱싱  (0) 2023.03.22
[MongoDB] 쿼리  (0) 2023.03.15
반응형
300x250