日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:14日期:2023-10-12 19:27:24

前言

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

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

圖形獲取區域坐標#

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

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

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

存儲位置

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

開放地理空間聯盟(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 WHEREMBRWithin (ST_GeomFromText(’POINT(39.991333490218544 116.30964748487895)’), polygon);# 在北京大學SELECT * FROM polygon WHEREMBRWithin (ST_GeomFromText(’POINT(39.988967560246685 116.3286905102832)’), polygon);# 不在北大

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

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

可見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 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩精品久久久久久久电影99爱| 亚洲国产欧美日本视频| 国产精品国产一区| 久久精品资源| 国产专区精品| 国产亚洲精aa在线看| 日本精品另类| 国产精品伦一区二区| 国产在线不卡一区二区三区| 91成人福利| 国产成人久久| 91精品1区| 日本va欧美va精品发布| 国产午夜一区| 中文字幕在线看片| 波多野结衣一区| 亚洲精品乱码| 日本激情一区| 欧美另类专区| 欧美日韩一区自拍| 国产精品大片| 亚洲大全视频| 日韩在线网址| 91视频一区| 亚洲一区国产一区| 久久影院一区二区三区| 亚洲福利一区| 国产精品一级在线观看| 色爱av综合网| 日韩动漫一区| 亚洲性色视频| 久久一区精品| 蜜桃视频一区二区三区在线观看| 精品国产亚洲一区二区三区| 欧美肉体xxxx裸体137大胆| 男人操女人的视频在线观看欧美| 91成人在线| 亚洲国产一区二区在线观看| 欧美精品中文字幕亚洲专区| 999精品色在线播放| 国产欧美69| 美女国产精品| 欧美日韩免费看片| 国产女人18毛片水真多18精品| 91精品在线观看国产| 老色鬼精品视频在线观看播放| 鲁大师影院一区二区三区| 成人福利视频| 国内精品伊人| 国产高清亚洲| 亚洲一区二区三区四区电影| 人人草在线视频| 鲁大师精品99久久久| 日韩精品成人在线观看| 丝袜国产日韩另类美女| 激情六月综合| 日韩三区在线| 国产一区二区三区四区二区| 国产精品tv| 国产精品一区二区三区av麻| 午夜精品影视国产一区在线麻豆| 99在线观看免费视频精品观看| 欧美羞羞视频| 国产拍在线视频| 超碰在线99| 亚洲黄色免费看| 日本美女一区| 欧美日韩免费观看一区=区三区 | 亚洲精品99| 免费欧美一区| 性欧美69xoxoxoxo| 欧美天堂亚洲电影院在线观看| 亚洲欧洲一区| 日本国产亚洲| 久久伊人亚洲| 99久久九九| 欧美精品一卡| 日韩高清三区| 国产精品久久久久久久免费软件| 欧美91在线|欧美| 97欧美在线视频| 欧美亚洲国产激情| 丝袜诱惑制服诱惑色一区在线观看| 免费久久精品视频| 毛片不卡一区二区| 日韩精品看片| 国产麻豆综合| 麻豆一区二区在线| 日韩高清不卡| 免费黄网站欧美| 精品国产一区二区三区性色av| 欧美精品观看| 日本欧美不卡| 蜜桃一区二区三区在线观看| 国产精品久久久久久久久免费高清 | 国产综合精品一区| 亚洲精品观看| 日韩欧美中文字幕一区二区三区| 国产精品99久久免费| 成人国产精品久久| 久久蜜桃av| 久久精品国产免费| 国产在线观看91一区二区三区| 久久婷婷久久| 日韩一区精品| 一区二区三区视频免费观看| 日韩精品导航| 在线国产一区二区| 亚洲精品观看| 日韩三区在线| 里番精品3d一二三区| 中文精品电影| 久久亚洲精品中文字幕蜜潮电影| 日欧美一区二区| 欧美国产小视频| 日韩黄色av| 爽爽淫人综合网网站| 亚洲天堂1区| 久久影视三级福利片| 在线精品福利| 午夜欧美精品久久久久久久| 精品中文在线| 国产欧美日韩精品高清二区综合区| 狠狠色综合网| 欧美影院三区| 麻豆精品蜜桃| 国产精品成久久久久| 久久xxx视频| 国产精品99精品一区二区三区∴| 日韩午夜黄色| 欧美精品一区二区久久| 日韩欧美一区二区三区在线观看 | 亚洲人成亚洲精品| 免费国产自线拍一欧美视频| 亚洲一级二级| 91久久亚洲| 亚洲自拍另类| 蜜桃视频一区二区三区在线观看| 日韩一级不卡| 蜜桃成人av| 女同性一区二区三区人了人一| 国产精品88久久久久久| 波多野结衣一区| 丝瓜av网站精品一区二区| 蜜桃av一区二区三区电影| 亚洲精品综合| 欧美伊人影院| 国产精品va| 日韩毛片视频| 日韩天堂av| 日本欧美一区| 亚洲天堂资源| 亚洲天堂免费| 免费看一区二区三区| 亚洲精品**中文毛片| 亚洲婷婷在线| 亚洲日本三级| 国产欧洲在线| 一区二区三区四区在线观看国产日韩| 日韩一区精品字幕| 鲁大师精品99久久久| 国产在线欧美| 亚洲精品系列| 偷拍精品精品一区二区三区| 亚洲欧美日韩在线观看a三区| 亚洲欧美网站在线观看| 精品视频97| 亚洲久久在线| 日韩电影免费网址| 视频一区二区欧美| 国产午夜精品一区在线观看| 精品成人18| 一区二区三区午夜视频| 国产成人精品一区二区免费看京 | 日韩欧美2区| 亚洲香蕉网站| 精品一区不卡| 中文字幕亚洲在线观看| 99久久夜色精品国产亚洲1000部| 欧美日韩精品一区二区三区在线观看| 99久久婷婷这里只有精品| 国产精品美女午夜爽爽| 视频一区在线视频| 国产一区二区三区黄网站| 久久亚洲影院| 亚洲国产日韩欧美在线| 日韩欧美综合| 免费日韩一区二区三区| 日本aⅴ精品一区二区三区| 午夜日本精品| 在线精品小视频| 在线一区免费| 国产一区视频在线观看免费| 久久青青视频| 日韩欧美自拍| 日本在线高清| 欧美黄色网页| 久久精品国产亚洲夜色av网站| 久久只有精品| 九九久久国产|