成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL空間函數實現位置打卡

數據庫 MySQL
項目需求是跟用戶當前位置判斷是否在給定的地理位置范圍內,符合位置限制才可以打卡,其中的位置范圍是一個或多個不規則的多邊形。如下圖,判斷用戶是在清華還是北大。

項目需求是跟用戶當前位置判斷是否在給定的地理位置范圍內,符合位置限制才可以打卡,其中的位置范圍是一個或多個不規則的多邊形。如下圖,判斷用戶是在清華還是北大。

 

MySQL空間函數實現位置打卡

圖形獲取區域坐標

因為項目前端使用微信小程序的wx.getLocation獲取地理位置,為了坐標的一致性,后臺選取區域范圍采用了騰訊地圖的地理位置服務,在應用工具->繪制幾何圖形里,提供了點、線、多邊形和圓形可以方便的選取 看這里 。

在官方提供的示例上稍加改動即可獲取選定的位置坐標。

 

MySQL空間函數實現位置打卡

存儲位置

取到坐標位置后,接著就是怎么存儲?

開放地理空間聯盟(OGC)是一個由 250多家公司,機構和大學組成的國際聯盟,參與開發公開可用的空間解決方案,這些解決方案可用于管理空間數據的各種應用程序。OGC發布了地理信息的 OpenGIS®Implementation 標準,該規范可從 OGC 網站http://www.opengeospatial.org/standards/sfs獲得。為了遵循 OGC 規范,MySQL 將空間 extensions 實現為具有 Geometry Types 環境的 SQL 的子集,提供生成、存儲、分析空間的功能??傊琈ySQL可以滿足我們的需求。

MySQL提供單個的存儲類型 POINT、LINESTRING、POLYGON 對應幾何圖形點、線、多邊形,GEOMETRY 可以存儲三種中的任何一種。同時擁有存儲多種類型的能力, MULTIPOINT、MULTILINESTRING、MULTIPOLYGON、GEOMETRYCOLLECTION依次對應單個圖形的復數。

回到項目中,我們用到的是 POLYGON ,

建表語句如下:

  1. CREATE TABLE `polygon` ( 
  2.   `id` int(10) unsigned NOT NULL AUTO_INCREMENT, 
  3.   `namevarchar(255) DEFAULT NULL
  4.   `polygon` polygon NOT NULL
  5.   PRIMARY KEY (`id`), 
  6.   SPATIAL KEY `d` (`polygon`) 
  7. DEFAULT CHARSET=utf8; 

插入數據

MySQL 支持將Well-Known 文本(WKT)格式和Well-Known 二進制(WKB)格式兩種格式轉換為object類型存儲起來,我們使用更易于理解的WKT格式。對WKB感興趣的可以 看這里 。

插入語句如下:

  1. INSERT INTO `polygon` VALUES ('1''清華大學', GeomFromText('POLYGON(( 
  2. 40.01169924229143 116.31565081888039,39.99304082299905 116.31616541796757,39.99343506780591 116.33297565023167,40.00237067000859 116.33743550702275,40.01340715321479 116.33057418815224,40.01169924229143 116.31565081888039))')); 
  3.  
  4. INSERT INTO `polygon` VALUES ('2''北京大學', GeomFromText('POLYGON((39.99711457525893 116.30450117461078,39.98673259872773 116.30535884106575,39.98673259872773 116.31702308311287,39.99963848242885 116.31598375134854,39.99711457525893 116.30450117461078))')); 

需要注意的是騰訊地圖返回的多邊形的點不是閉合的,而polygon函數需要為了確定多邊形是否閉合要求第一個點和最后一個點是一樣的。如果不是閉合的polygon返回的結果將是NULL,插入語句就會執行失敗。

如果幾何滿足諸如此(非窮舉)列表中的條件,則它在語法上是 well-formed:

  • 線串至少有兩個點
  • 多邊形至少有一個環
  • 多邊形環關閉(第一個和最后一個點相同)
  • 多邊形環至少有 4 個點(最小多邊形是一個三角形,第一個和最后一個點相同)
  • 集合不為空(除了GeometryCollection)

查詢判斷

  1. SELECT * FROM polygon WHERE 
  2.     MBRWithin (ST_GeomFromText('POINT(39.991333490218544 116.30964748487895)'), polygon); 
  3. # 在北京大學 
  4.  
  5. SELECT * FROM polygon WHERE 
  6.     MBRWithin (ST_GeomFromText('POINT(39.988967560246685 116.3286905102832)'), polygon); 
  7. # 不在北大 

細心的同學可能發現了這里的查詢語句里用的是函數,在以往的SQL里如果存在查詢字段上使用函數必然導致索引失效、全表掃描,但是在空間數據上不會,先看 EXPLAIN 語句和結果:

 

MySQL空間函數實現位置打卡

可見MySQL空間類型的數據同樣可以建立索引,使用的關鍵詞是 SPATIAL用法如下:

  1. CREATE TABLE geom (g GEOMETRY NOT NULL); 
  2. CREATE SPATIAL INDEX g ON geom (g); 

常用的空間計算函數

1、判斷兩點之間的距離

  • ST_Distance(g1,g2),返回g1和g2之間的距離。如果任一參數是NULL或空幾何,則 return value 為NULL。

2、圖形1是否完全包含圖形2

  • ST_Contains(g1,g2),返回 1 或 0 以指示 g1 是否完全包含 g2 。還可以用ST_Within(g2,g1)達到相同的效果。

3、不相交

  • ST_Disjoint(g1,g2),返回 1 或 0 以指示 g1 是否在空間上與(不相交) g2 不相交。

4、關于圖形相交的情況比較復雜,包含重疊、外相交等情況,具體可以 看這里

總結

本文通過一個地理位置打卡的需求,使用 MySQL 自帶的 Polygon 數據類型實現了空間數據的存儲,用ST_Contains(g1,g2) 函數代入了后臺預置的地理區域和前端獲取到的用戶地理位置可以得出用戶是否在打卡范圍內。其中還涉及到了 MySQL 在使用函數作為查詢字段的情況下依然可以使用索引,最后延伸了一些其他的空間處理函數。

責任編輯:未麗燕 來源: 古道博客
相關推薦

2010-05-25 15:12:22

MySQL分頁

2010-11-25 11:57:42

MySQL查詢行號

2009-04-16 17:38:24

SQL Server 空間數據智能

2009-02-25 13:41:49

全文搜索內置函數MySQL

2010-11-16 11:32:54

ORACLE增加表空間

2010-10-13 11:24:27

MySQL數據目錄

2010-11-26 16:37:41

MySQL日志文件

2010-10-09 15:35:25

MySQL rand函

2009-10-28 16:31:37

Oracle傳輸表空間

2010-10-27 14:41:45

Oracle查詢用戶表

2021-10-08 08:58:35

MySQL函數脫敏

2009-06-04 09:47:48

MySQL隱藏控件TMPDIR

2021-09-08 19:35:02

MySQL Keyring加密

2021-01-20 13:50:45

MySQL數據庫代碼

2021-07-05 05:30:37

AR物布空間應用

2024-07-09 08:37:13

2010-11-25 11:01:33

MySQL日期函數

2020-07-16 10:52:27

釘釘打卡Python

2011-02-21 13:23:54

微軟 SQL Serv

2021-01-08 08:10:34

MySQL表空間回收
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人免费视频观看视频 | 免费观看一级特黄欧美大片 | 日日夜夜影院 | 久久久久久亚洲精品 | 欧美精产国品一二三区 | 成人av观看| 欧美日韩亚洲视频 | 久久精品中文 | www.狠狠干| 在线一区二区观看 | 成人在线影视 | 国产精品久久精品 | 91精品国产99 | 国产精品久久久久久久久免费软件 | 日韩中文视频 | 麻豆一区二区三区 | 欧美日韩精品在线一区 | 夜夜操操操| 999久久精品| 国产欧美一区二区三区另类精品 | 在线观看免费黄色片 | 综合精品在线 | 一区二区三区四区不卡视频 | 亚洲成人免费视频在线 | 成人欧美一区二区三区黑人孕妇 | 久久综合入口 | 日韩av一区二区在线观看 | 在线观看特色大片免费网站 | 亚洲视频在线观看 | 国产福利一区二区 | 人操人免费视频 | 欧美一级片久久 | 亚洲精品一区二区三区中文字幕 | 久草在线视频中文 | 久久久蜜臀国产一区二区 | 免费看a| 欧美午夜一区二区三区免费大片 | 日韩精品免费播放 | 亚洲精品乱码久久久久久久久 | 成年人在线观看视频 | 91一区二区三区在线观看 |