溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL中怎么利用空間函數(shù)實(shí)現(xiàn)位置打卡

發(fā)布時(shí)間:2021-07-14 14:21:04 來源:億速云 閱讀:132 作者:Leah 欄目:數(shù)據(jù)庫

這篇文章將為大家詳細(xì)講解有關(guān)MySQL中怎么利用空間函數(shù)實(shí)現(xiàn)位置打卡,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

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

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

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

MySQL中怎么利用空間函數(shù)實(shí)現(xiàn)位置打卡

存儲位置

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

開放地理空間聯(lián)盟(OGC)是一個(gè)由  250多家公司,機(jī)構(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  實(shí)現(xiàn)為具有 Geometry Types 環(huán)境的 SQL 的子集,提供生成、存儲、分析空間的功能??傊琈ySQL可以滿足我們的需求。

MySQL提供單個(gè)的存儲類型 POINT、LINESTRING、POLYGON 對應(yīng)幾何圖形點(diǎn)、線、多邊形,GEOMETRY  可以存儲三種中的任何一種。同時(shí)擁有存儲多種類型的能力,  MULTIPOINT、MULTILINESTRING、MULTIPOLYGON、GEOMETRYCOLLECTION依次對應(yīng)單個(gè)圖形的復(fù)數(shù)。

回到項(xiàng)目中,我們用到的是 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))'));

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

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

  • 線串至少有兩個(gè)點(diǎn)

  • 多邊形至少有一個(gè)環(huán)

  • 多邊形環(huán)關(guān)閉(第一個(gè)和最后一個(gè)點(diǎn)相同)

  • 多邊形環(huán)至少有 4 個(gè)點(diǎn)(最小多邊形是一個(gè)三角形,第一個(gè)和最后一個(gè)點(diǎn)相同)

  • 集合不為空(除了GeometryCollection)

查詢判斷

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

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

MySQL中怎么利用空間函數(shù)實(shí)現(xiàn)位置打卡

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

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

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

1、判斷兩點(diǎn)之間的距離

  • 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ù)雜,包含重疊、外相交等情況,具體可以 看這里

關(guān)于MySQL中怎么利用空間函數(shù)實(shí)現(xiàn)位置打卡就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI