itwanqqqqq 2023-03-15 12:23 采纳率: 100%
浏览 72
已结题

查询不规则区域中的数据

在订单表中有经纬度字段,百万数据,求在不规则区域中的订单。
这个区域可人为改变,画的形状不一,一画出来最快得出区域范围内的所有订单

  • 写回答

6条回答 默认 最新

  • CodeBytes 2023-03-15 12:35
    关注

    该回答引用ChatGPT

    如有疑问,可以回复我!

    要解决这个问题,您需要使用MySQL的空间数据类型和空间函数。在这里,我们可以将经纬度字段存储为POINT类型,并使用MySQL的ST_CONTAINS函数来检查该点是否在指定的不规则区域内。

    以下是您可以执行的基本步骤:

    创建订单表并将经纬度字段存储为POINT类型:

    CREATE TABLE orders (
      order_id INT PRIMARY KEY,
      location POINT
    );
    
    
    

    ALTER TABLE orders ADD SPATIAL INDEX(location);
    向订单表中添加数据:

    INSERT INTO orders (order_id, location) VALUES
    (1, POINT(40.7128, -74.0060)),
    (2, POINT(37.7749, -122.4194)),
    (3, POINT(41.8781, -87.6298)),
    (4, POINT(34.0522, -118.2437)),
    
    

    ...;
    创建一个不规则区域,可以使用MySQL的ST_GEOMFROMTEXT函数将WKT(Well-Known Text)字符串转换为几何对象。例如,以下代码将创建一个多边形区域:

    
    SET @polygon = 'POLYGON((40.748817 -73.985428, 40.748817 -73.975428, 40.758817 -73.975428, 40.758817 -73.985428, 40.748817 -73.985428))';
    SET @polygon_geom = ST_GEOMFROMTEXT(@polygon);
    
    

    使用ST_CONTAINS函数来查找在不规则区域中的订单:

    SELECT * FROM orders WHERE ST_CONTAINS(@polygon_geom, location);
    
    

    这将返回在不规则区域中的所有订单。请注意,如果您的订单表中有很多数据,则这可能需要一些时间来运行。您可以考虑使用索引和分区来优化查询性能。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 3月24日
  • 已采纳回答 3月16日
  • 创建了问题 3月15日

悬赏问题

  • ¥15 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号