国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

利用MySQL空間函數(shù)實現(xiàn)位置打卡的完整步驟

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

前言

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

利用MySQL空間函數(shù)實現(xiàn)位置打卡的完整步驟

圖形獲取區(qū)域坐標(biāo)#

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

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

利用MySQL空間函數(shù)實現(xiàn)位置打卡的完整步驟

存儲位置

取到坐標(biāo)位置后,接著就是怎么存儲?

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

回到項目中,我們用到的是 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;

插入數(shù)據(jù)

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

插入語句如下:

INSERT INTO `polygon` VALUES (’1’, ’清華大學(xué)’, 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’, ’北京大學(xué)’, GeomFromText(’POLYGON((39.99711457525893 116.30450117461078,39.98673259872773 116.30535884106575,39.98673259872773 116.31702308311287,39.99963848242885 116.31598375134854,39.99711457525893 116.30450117461078))’));

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

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

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

查詢判斷

SELECT * FROM polygon WHEREMBRWithin (ST_GeomFromText(’POINT(39.991333490218544 116.30964748487895)’), polygon);# 在北京大學(xué)SELECT * FROM polygon WHEREMBRWithin (ST_GeomFromText(’POINT(39.988967560246685 116.3286905102832)’), polygon);# 不在北大

細(xì)心的同學(xué)可能發(fā)現(xiàn)了這里的查詢語句里用的是函數(shù),在以往的SQL里如果存在查詢字段上使用函數(shù)必然導(dǎo)致索引失效、全表掃描,但是在空間數(shù)據(jù)上不會,先看 EXPLAIN 語句和結(jié)果:

利用MySQL空間函數(shù)實現(xiàn)位置打卡的完整步驟

可見MySQL空間類型的數(shù)據(jù)同樣可以建立索引,使用的關(guān)鍵詞是 SPATIAL

用法如下:

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

常用的空間計算函數(shù)

1、判斷兩點之間的距離

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

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

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

3、不相交

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

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

總結(jié)

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

到此這篇關(guān)于利用MySQL空間函數(shù)實現(xiàn)位置打卡的文章就介紹到這了,更多相關(guān)MySQL空間函數(shù)位置打卡內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 国产成人欧美视频在线 | 亚洲精品一二三四区 | 国产偷国产偷亚洲高清在线 | 欧美精品片| 高清免费国产在线观看 | 男女男在线精品网站免费观看 | 欧美午夜在线播放 | 久草热久草在线 | 黄 色 免费网 站 成 人 | 91久久精一区二区三区大全 | 国产系列在线观看 | 精品久久久久久亚洲 | 男人的天堂在线免费视频 | 免费嗨片 | 色久激情| 男人和女人的做刺激性视频 | 亚洲在线免费免费观看视频 | 国产玖玖在线观看 | 亚洲午夜片 | 日本九六视频 | a欧美| 欧美一级网 | 手机在线精品视频每日更新 | 久久一区二区三区免费播放 | 欧美成人免费看片一区 | 97在线公开视频 | 久草在线视频资源 | 99精品视频免费 | 亚洲欧美另类日本久久影院 | a级黄色毛片免费播放视频 a级精品九九九大片免费看 | 在线观看亚洲视频 | 一级毛片不卡免费看老司机 | 欧美精品免费在线 | 欧美一级毛片免费看 | 欧美日韩精品国产一区二区 | 浮力影院网站午夜 | 黄色一级片网址 | 国产成人毛片视频不卡在线 | 视频一区二区三区自拍 | 亚洲国产福利精品一区二区 | 亚洲偷|