首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用有标签和lat,lng坐标的位置来模拟事件?

如何用有标签和lat,lng坐标的位置来模拟事件?
EN

Stack Overflow用户
提问于 2017-08-24 22:39:15
回答 1查看 40关注 0票数 0

假设在这个位置发生了一个特殊事件:

代码语言:javascript
复制
{
  label: 'Mountain View',
  lat: 37.4224764,
  lng: -122.0842499
}

你将如何存储这些信息,为什么?

1)单表

代码语言:javascript
复制
events: id place_label coordinates(point)

2)两个独立的表

代码语言:javascript
复制
events: id place_id
places: place_id label coordinates(point)

3)使用jsonb数据类型的单表

代码语言:javascript
复制
events: id place(jsonb)

或者另一种方式?

最终目标是使用地理空间扩展(例如EarthDistance、PostGIS)来执行“查找___英里内的所有事件”之类的查询。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-24 23:05:44

执行两个单独的表,否则会遇到查询大于需要的点多边形表的缺点。

代码语言:javascript
复制
CREATE TABLE places 
(
     id_place serial PRIMARY KEY,
     name     text,
     geom     geography(POINT)
);

CREATE INDEX ON places USING gist(geom);

CREATE TABLE events 
(
    id_event serial PRIMARY KEY, 
    id_place int    REFERENCES place,
    start_ts timestamp
);

最终目标是使用地理空间扩展(例如EarthDistance、PostGIS)来执行“查找___英里内的所有事件”之类的查询。

代码语言:javascript
复制
SELECT *
FROM events AS e
JOIN places AS p USING (id_place)
WHERE ST_DWithin(p.geom, ST_MakePoint(long,lat)::geography, miles*1609);

这是miles of (long,lat)中的所有事件。我不会使用earthdistance,我只会使用PostGIS。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45871943

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档