婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 利用MySQL空間函數實現位置打卡的完整步驟

利用MySQL空間函數實現位置打卡的完整步驟

熱門標簽:地圖標注客戶付款 臨沂做地圖標注 宜賓全自動外呼系統廠家 廣東400企業電話申請流程 咸陽防封電銷卡 新鄉智能外呼系統好處 石家莊400電話辦理公司 許昌外呼增值業務線路 申請400電話電話價格

前言

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

圖形獲取區域坐標#

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

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

存儲位置

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

開放地理空間聯盟(OGC)是一個由 250多家公司,機構和大學組成的國際聯盟,參與開發公開可用的空間解決方案,這些解決方案可用于管理空間數據的各種應用程序。OGC發布了地理信息的 OpenGIS®Implementation 標準,該規范可從 OGC 網站http://www.opengeospatial.org/standards/sfs獲得。為了遵循 OGC 規范,MySQL 將空間 extensions 實現為具有 Geometry Types 環境的 SQL 的子集,提供生成、存儲、分析空間的功能。總之,MySQL可以滿足我們的需求。
MySQL提供單個的存儲類型 POINT、LINESTRING、POLYGON 對應幾何圖形點、線、多邊形,GEOMETRY 可以存儲三種中的任何一種。同時擁有存儲多種類型的能力, MULTIPOINT、MULTILINESTRING、MULTIPOLYGON、GEOMETRYCOLLECTION依次對應單個圖形的復數。

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

建表語句 如下:

CREATE TABLE `polygon` (
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
 `name` varchar(255) DEFAULT NULL,
 `polygon` polygon NOT NULL,
 PRIMARY KEY (`id`),
 SPATIAL KEY `d` (`polygon`)
) DEFAULT CHARSET=utf8;

插入數據

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

插入語句如下:

INSERT INTO `polygon` VALUES ('1', '清華大學', GeomFromText('POLYGON((
40.01169924229143 116.31565081888039,39.99304082299905 116.31616541796757,39.99343506780591 116.33297565023167,40.00237067000859 116.33743550702275,40.01340715321479 116.33057418815224,40.01169924229143 116.31565081888039))'));

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)

查詢判斷

SELECT * FROM polygon WHERE
	MBRWithin (ST_GeomFromText('POINT(39.991333490218544 116.30964748487895)'), polygon);
# 在北京大學

SELECT * FROM polygon WHERE
	MBRWithin (ST_GeomFromText('POINT(39.988967560246685 116.3286905102832)'), polygon);
# 不在北大

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

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

用法如下:

CREATE TABLE geom (g GEOMETRY NOT NULL);
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 在使用函數作為查詢字段的情況下依然可以使用索引,最后延伸了一些其他的空間處理函數。

到此這篇關于利用MySQL空間函數實現位置打卡的文章就介紹到這了,更多相關MySQL空間函數位置打卡內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • mysql 無限級分類實現思路
  • Mysql使用索引實現查詢優化
  • 利用mysql實現的雪花算法案例

標簽:合肥 日照 臺灣 北京 貴州 阜新 鎮江 鷹潭

巨人網絡通訊聲明:本文標題《利用MySQL空間函數實現位置打卡的完整步驟》,本文關鍵詞  利用,MySQL,空間,函數,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《利用MySQL空間函數實現位置打卡的完整步驟》相關的同類信息!
  • 本頁收集關于利用MySQL空間函數實現位置打卡的完整步驟的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美区一区二区三区| 色综合天天综合给合国产| 国内精品第一页| 欧美不卡在线视频| 国内精品久久久久影院色| 精品免费国产一区二区三区四区| 美女尤物国产一区| 欧美精品一区二区三区在线 | 国产精品1区2区3区在线观看| 久久视频一区二区| 国产不卡高清在线观看视频| 亚洲欧洲一区二区在线播放| 欧美色图在线观看| 精品一区二区三区在线观看国产| 国产精品网站在线| 欧洲国产伦久久久久久久| 久久精品国产精品亚洲红杏| 国产精品进线69影院| 欧美日韩二区三区| 大陆成人av片| 日日噜噜夜夜狠狠视频欧美人 | 亚洲自拍偷拍麻豆| 欧美成人vps| 色婷婷国产精品综合在线观看| 蜜臀久久久久久久| 国产精品不卡一区| 日韩欧美国产高清| 91国偷自产一区二区三区成为亚洲经典| 亚洲国产欧美在线| 久久久亚洲国产美女国产盗摄 | 久久日韩粉嫩一区二区三区| 91在线观看污| 国产在线精品一区二区夜色 | 亚洲靠逼com| www国产精品av| 欧美日韩在线播放三区| 成人av一区二区三区| 日本不卡123| 亚洲免费大片在线观看| 国产日韩欧美精品电影三级在线 | 欧美国产在线观看| 欧美精品18+| 欧洲av一区二区嗯嗯嗯啊| 国产精品亚洲成人| 国产一区二区三区观看| 日韩精品色哟哟| 一级中文字幕一区二区| 欧美激情中文不卡| 久久人人爽爽爽人久久久| 欧美日本韩国一区| 欧美日韩三级一区| 欧美日韩免费在线视频| 在线观看av一区| 91色九色蝌蚪| 91福利资源站| 欧美色图12p| 欧美天堂一区二区三区| 欧美日韩专区在线| 欧美裸体一区二区三区| 欧美福利视频导航| 欧美精品三级日韩久久| 欧美另类久久久品| 日韩亚洲欧美综合| 欧美不卡一二三| 中文字幕免费不卡在线| 国产精品视频你懂的| 亚洲欧美一区二区三区极速播放 | 日韩国产欧美在线播放| 一区二区三区高清在线| 亚洲成人激情av| 日韩成人精品在线| 国产在线精品国自产拍免费| 国产成人av电影在线观看| 成人午夜视频免费看| 99在线热播精品免费| 欧洲在线/亚洲| 91精品国产91久久综合桃花| 欧美一区二区三区免费观看视频| 欧美大尺度电影在线| 精品国产一区二区在线观看| 国产精品乱码一区二区三区软件| 亚洲欧美一区二区在线观看| 亚洲综合在线五月| 久草精品在线观看| av一区二区三区| 欧美一区午夜视频在线观看| 国产亚洲精品bt天堂精选| 最新久久zyz资源站| 日韩成人免费电影| a亚洲天堂av| 欧美二区乱c少妇| 国产三级欧美三级| 亚洲第一综合色| 国产成人aaa| 在线播放中文字幕一区| 久久久不卡网国产精品一区| 亚洲三级在线看| 国产老妇另类xxxxx| 欧美日韩国产一级| 国产精品家庭影院| 精品影院一区二区久久久| 日本高清不卡视频| 中文字幕国产一区二区| 蜜臀av性久久久久蜜臀aⅴ| 91在线观看成人| 久久网站最新地址| 欧美a级理论片| 欧美日韩国产色站一区二区三区| 欧美激情一区二区在线| 伦理电影国产精品| 欧美午夜电影网| 国产精品久久久久久久久免费樱桃 | 国产精品青草综合久久久久99| 亚洲综合一二三区| 97久久人人超碰| 久久精品一区二区三区四区| 喷水一区二区三区| 欧美日韩www| 亚洲国产精品自拍| 欧美亚洲日本国产| 一区二区三国产精华液| 99久久国产综合精品女不卡| 中文字幕不卡在线播放| 丁香一区二区三区| 久久久久久久综合狠狠综合| 久久精品99久久久| 日韩一区二区高清| 蜜桃精品视频在线观看| 欧美精品色综合| 婷婷中文字幕综合| 精品视频资源站| 水蜜桃久久夜色精品一区的特点| 在线精品视频小说1| 一区二区三区精品久久久| 欧洲精品在线观看| 五月天一区二区| 337p亚洲精品色噜噜| 日韩综合小视频| 精品人伦一区二区色婷婷| 精品夜夜嗨av一区二区三区| 精品久久久久久久久久久院品网| 久久精工是国产品牌吗| www久久久久| 91麻豆成人久久精品二区三区| 亚洲精品视频一区| 欧美麻豆精品久久久久久| 麻豆精品新av中文字幕| 久久久精品天堂| 99久久精品费精品国产一区二区| 国产精品不卡一区| 色婷婷久久综合| 天天色图综合网| 欧美成人vps| 93久久精品日日躁夜夜躁欧美| 亚洲精品大片www| 欧美一级片免费看| 国产成人午夜精品5599 | 国产精品久久久久婷婷二区次| 91免费国产视频网站| 日本91福利区| 日本一区二区三区在线不卡| 91成人在线观看喷潮| 久久国产精品72免费观看| 亚洲国产成人午夜在线一区| 欧美午夜一区二区三区免费大片| 麻豆成人在线观看| 国产精品麻豆久久久| 日韩欧美一区二区三区在线| 国产精品亚洲一区二区三区在线| 亚洲影视在线观看| 久久久国产精品午夜一区ai换脸| 91久久精品一区二区| 国产精品一卡二卡在线观看| 亚洲成人精品一区| 国产女主播视频一区二区| 欧美猛男gaygay网站| 国产91丝袜在线观看| 日本不卡中文字幕| 一区二区三区四区不卡在线| 久久男人中文字幕资源站| 欧美日韩国产bt| 色婷婷综合在线| 国产成人精品一区二区三区四区| 午夜久久久久久| 国产精品成人在线观看| 日韩欧美国产三级| 欧美日韩另类国产亚洲欧美一级| 成人激情免费视频| 国产精品一区在线观看乱码| 日本欧美一区二区三区| 一区二区欧美在线观看| 国产精品第四页| 中文字幕av一区二区三区高 | 中文字幕在线不卡视频| 精品国产123| 9191精品国产综合久久久久久| 日本丶国产丶欧美色综合| av一区二区不卡| 99久久久久久| 91香蕉视频黄|