亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁(yè) > 知識(shí)庫(kù) > 利用MySQL空間函數(shù)實(shí)現(xiàn)位置打卡的完整步驟

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

熱門標(biāo)簽:地圖標(biāo)注客戶付款 臨沂做地圖標(biāo)注 宜賓全自動(dòng)外呼系統(tǒng)廠家 廣東400企業(yè)電話申請(qǐng)流程 咸陽(yáng)防封電銷卡 新鄉(xiāng)智能外呼系統(tǒng)好處 石家莊400電話辦理公司 許昌外呼增值業(yè)務(wù)線路 申請(qǐng)400電話電話價(jià)格

前言

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

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

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

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

存儲(chǔ)位置

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

開放地理空間聯(lián)盟(OGC)是一個(gè)由 250多家公司,機(jī)構(gòu)和大學(xué)組成的國(guó)際聯(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 的子集,提供生成、存儲(chǔ)、分析空間的功能。總之,MySQL可以滿足我們的需求。
MySQL提供單個(gè)的存儲(chǔ)類型 POINT、LINESTRING、POLYGON 對(duì)應(yīng)幾何圖形點(diǎn)、線、多邊形,GEOMETRY 可以存儲(chǔ)三種中的任何一種。同時(shí)擁有存儲(chǔ)多種類型的能力, MULTIPOINT、MULTILINESTRING、MULTIPOLYGON、GEOMETRYCOLLECTION依次對(duì)應(yīng)單個(gè)圖形的復(fù)數(shù)。

回到項(xiàng)目中,我們用到的是 POLYGON ,

建表語(yǔ)句 如下:

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類型存儲(chǔ)起來(lái),我們使用更易于理解的WKT格式。對(duì)WKB感興趣的可以看這里。

插入語(yǔ)句如下:

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,插入語(yǔ)句就會(huì)執(zhí)行失敗。

如果幾何滿足諸如此(非窮舉)列表中的條件,則它在語(yǔ)法上是 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)了這里的查詢語(yǔ)句里用的是函數(shù),在以往的SQL里如果存在查詢字段上使用函數(shù)必然導(dǎo)致索引失效、全表掃描,但是在空間數(shù)據(jù)上不會(huì),先看 EXPLAIN 語(yǔ)句和結(jié)果:

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

總結(jié)

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

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

您可能感興趣的文章:
  • mysql 無(wú)限級(jí)分類實(shí)現(xiàn)思路
  • Mysql使用索引實(shí)現(xiàn)查詢優(yōu)化
  • 利用mysql實(shí)現(xiàn)的雪花算法案例

標(biāo)簽:合肥 日照 臺(tái)灣 北京 貴州 阜新 鎮(zhèn)江 鷹潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用MySQL空間函數(shù)實(shí)現(xiàn)位置打卡的完整步驟》,本文關(guān)鍵詞  利用,MySQL,空間,函數(shù),實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《利用MySQL空間函數(shù)實(shí)現(xiàn)位置打卡的完整步驟》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于利用MySQL空間函數(shù)實(shí)現(xiàn)位置打卡的完整步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日韩在线观看免费| 欧美激情一区二区三区中文字幕| 午夜欧美成人久久久久久| 九九国产| 天天做人人爱夜夜爽2020毛片| 91麻豆精品国产自产在线观看一区 | 台湾毛片| 亚欧乱色一区二区三区| 日韩专区亚洲综合久久| 精品国产一区二区三区久久久狼 | 亚洲精品影院久久久久久| 一级片免费在线观看视频| 国产综合成人观看在线| 日本免费看视频| 日韩在线观看视频黄| 91麻豆精品国产高清在线| 四虎影视精品永久免费网站| 日韩专区第一页| 国产麻豆精品| 99色吧| 韩国毛片 免费| 欧美a级v片不卡在线观看| 台湾毛片| 国产高清视频免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品视频在线看 | 国产伦精品一区二区三区在线观看| 久久国产精品永久免费网站| 国产伦精品一区二区三区无广告| 一级女性全黄生活片免费| 日本伦理网站| 一本高清在线| 国产a网| 国产一区二区精品尤物| 99久久精品国产片| 国产网站免费观看| 九九久久99| 九九九在线视频| 日本伦理网站| 97视频免费在线观看| 精品国产香蕉在线播出 | 成人免费网站久久久| 日韩欧美一及在线播放| 精品久久久久久中文字幕一区| 天天做日日爱夜夜爽| 久久99青青久久99久久| 欧美激情一区二区三区视频| 亚欧视频在线| 国产成人精品影视| 精品视频免费看| 999久久66久6只有精品| 四虎久久影院| 精品视频在线看 | 日本特黄特色aa大片免费| 四虎影视久久久| 国产高清视频免费| 99久久精品费精品国产一区二区| 午夜在线亚洲男人午在线| 精品久久久久久中文字幕一区| 99色精品| 九九国产| 日韩中文字幕一区| 国产亚洲精品aaa大片| 九九久久国产精品大片| 欧美激情一区二区三区在线| 四虎影视久久久| 久久国产精品自由自在| 国产一区二区高清视频| 国产视频一区二区在线播放| 欧美a级v片不卡在线观看| 在线观看导航| 国产一级强片在线观看| 亚洲精品久久玖玖玖玖| 欧美电影免费看大全| 韩国三级香港三级日本三级| 毛片高清| 成人av在线播放| 日韩女人做爰大片| 麻豆网站在线看| 欧美a级v片不卡在线观看| 亚洲第一页乱| 青草国产在线观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 高清一级片| 成人免费观看男女羞羞视频| 九九久久99综合一区二区| 国产高清在线精品一区二区 | 日本在线不卡视频| 99色视频在线| 四虎影视库国产精品一区| 午夜在线亚洲男人午在线| 国产成人精品综合| 亚洲天堂一区二区三区四区| 色综合久久天天综线观看| 麻豆系列 在线视频| 久草免费在线视频| 一级毛片视频在线观看| 国产91精品一区二区| 成人a大片高清在线观看| 国产网站在线| a级毛片免费全部播放| 亚欧成人毛片一区二区三区四区| 精品久久久久久免费影院| 国产一区二区精品久| 免费国产在线观看不卡| 国产视频网站在线观看| 天天做日日爱| 亚洲精品影院| 欧美18性精品| 国产亚洲免费观看| 日韩一级黄色| 精品国产一区二区三区久久久狼 | 黄视频网站在线看| 日韩专区在线播放| 免费的黄色小视频| 九九免费高清在线观看视频| 成人免费网站久久久| 一级毛片视频播放| 精品视频在线观看一区二区| 台湾美女古装一级毛片| 亚洲第一色在线| 999精品在线| 久久久久久久男人的天堂| 国产一级生活片| 成人免费观看的视频黄页| 国产高清在线精品一区a| 国产美女在线观看| 久久久久久久男人的天堂| 国产伦精品一区三区视频| 久久成人亚洲| 精品国产一区二区三区久| 久久精品店| 久久国产精品永久免费网站| 国产精品自拍在线观看| 免费一级片网站| 天天色成人网| 日韩一级黄色大片| 亚洲不卡一区二区三区在线| 国产一区精品| 日本特黄特黄aaaaa大片| 亚欧成人乱码一区二区| 毛片高清| 精品久久久久久影院免费| 午夜精品国产自在现线拍| 欧美激情影院| 日本特黄特黄aaaaa大片| 四虎影视久久久免费| 99色吧| 天天做人人爱夜夜爽2020毛片| 四虎影视库| 在线观看导航| 国产视频网站在线观看| 国产一区二区精品久久91| 99久久精品国产麻豆| 精品国产香蕉在线播出| 国产不卡在线观看视频| 国产一区精品| 亚欧成人毛片一区二区三区四区| 国产美女在线一区二区三区| 日韩女人做爰大片| 韩国毛片| 黄色免费网站在线| 欧美激情一区二区三区在线| 欧美国产日韩一区二区三区| 精品国产亚一区二区三区| 国产91精品一区二区| 久久国产精品自由自在| 久久99青青久久99久久| 国产不卡高清在线观看视频| 国产a免费观看| 亚洲天堂在线播放| 久草免费在线观看| 九九九在线视频| 精品国产一区二区三区精东影业| 美女免费精品视频在线观看| 精品国产一区二区三区国产馆| 黄视频网站免费看| 欧美日本免费| 国产福利免费视频| 欧美国产日韩一区二区三区| 日本特黄特黄aaaaa大片| 久草免费在线视频| 午夜在线亚洲| 黄色短视屏| 日韩在线观看免费| 精品在线视频播放| 欧美国产日韩精品| 久草免费在线观看| 国产精品12| 免费国产在线观看| 99久久精品国产国产毛片 | 精品国产一区二区三区久| 美女免费毛片| 精品久久久久久综合网| 久久99爰这里有精品国产| 亚洲天堂免费| 久久国产精品自由自在| 精品视频在线观看一区二区三区| 国产精品免费久久| 可以免费看毛片的网站|