日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

geojson mysql存储_mongodb存储geoJson

發(fā)布時(shí)間:2024/3/24 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 geojson mysql存储_mongodb存储geoJson 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在業(yè)務(wù)需求中,需要對(duì)地理坐標(biāo)進(jìn)行存儲(chǔ),mongodb是一種很好的選擇,因?yàn)樗峁┝嗽S多關(guān)于地理位置的方法,但是它提供的GeoJson卻是一個(gè)接口,當(dāng)然也提供了對(duì)應(yīng)的點(diǎn)、線、面的實(shí)現(xiàn)類,不過在業(yè)務(wù)需求中,往往需要前端傳一個(gè)GeoJson數(shù)據(jù)格式,后端做一個(gè)點(diǎn)、線、面的適配,已達(dá)到簡(jiǎn)單使用,簡(jiǎn)單存儲(chǔ)的功能;

基于上面的場(chǎng)景,寫了這篇文章,下面就貼代碼了(關(guān)于maven及mongdb的配置下面就不貼了,只貼核心代碼)

1.首先自定義一個(gè)GeoJson類

@Data

public class CustomGeoJson implements GeoJson {

private String type;

private Iterable> coordinates;

}

2.添加mongdb的convert轉(zhuǎn)換器,讀寫用的

1)CustomReadGeoJsonConverter

@ReadingConverter

public class CustomReadGeoJsonConverter implements Converter {

@Override

public CustomGeoJson convert(Document document) {

CustomGeoJson geoJson = new CustomGeoJson();

geoJson.setType(document.get(GeoJsonConstant.TYPE, String.class));

geoJson.setCoordinates(document.get(GeoJsonConstant.COORDINATES, Iterable.class));

return geoJson;

}

}

2)CustomWriteGeoJsonConverter

@WritingConverter

public class CustomWriteGeoJsonConverter implements Converter {

@Override

public Document convert(CustomGeoJson geoJson) {

Document document = new Document();

document.put(GeoJsonConstant.TYPE, geoJson.getType());

document.put(GeoJsonConstant.COORDINATES, geoJson.getCoordinates());

return document;

}

}

3.geoJson數(shù)據(jù)的鍵名稱

public final class GeoJsonConstant {

/**

* type(類型)

*/

public static final String TYPE = "type";

/**

* coordinates(坐標(biāo)位置)

*/

public static final String COORDINATES = "coordinates";

}

4.geoJson的type

public final class GeoJsonTypeConstant {

/**

* 點(diǎn)

*/

public static final String POINT = "Point";

/**

* 線

*/

public static final String LINESTRING = "LineString";

/**

* 面

*/

public static final String POLYGON = "Polygon";

}

實(shí)體類

@Data

@Document(collection = "map_data")

public class MapData {

@Id

private String id;

private CustomGeoJson geometry;

}

6.TestController

@RestController

@Api

public class TestController {

@Autowired

private MongoTemplate mongoTemplate;

@PostMapping("test")

public MapData test(@RequestBody MapData mapData){

return mongoTemplate.insert(mapData);

}

}

7.測(cè)試效果圖

swagger入?yún)?/p>

企業(yè)微信截圖_08821638-8255-4b6f-92aa-3a85efa2c2c9.png

8.mongdb 存儲(chǔ)數(shù)據(jù)的值

企業(yè)微信截圖_0ee06576-194f-4ad1-bf60-cd320312afb0.png

以上就是GeoJson存儲(chǔ)地理位置的實(shí)現(xiàn);

有疑問或者有更好的實(shí)現(xiàn)方式可以討論,本文屬于原創(chuàng),轉(zhuǎn)載需指明出處

總結(jié)

以上是生活随笔為你收集整理的geojson mysql存储_mongodb存储geoJson的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。