sqlserver空間數據 + c# 實現查詢附近的設備

来源:https://www.cnblogs.com/jionsoft/archive/2020/03/16/12503137.html
-Advertisement-
Play Games

前言 一個小需求的實現,做一個備忘,個人理解,可能存在錯誤。 客戶有很多設備,這些設備分散在不同的地方,現在需要通過小程式獲取附近的(比如1000米)之類的設備列表,以距離排序 第一個想到的的是找百度/騰訊等地圖,看有沒有提供相應的開放api,先將我們的設備id以及對應的經緯度存儲到地圖中,再調用某 ...


前言

一個小需求的實現,做一個備忘,個人理解,可能存在錯誤。

客戶有很多設備,這些設備分散在不同的地方,現在需要通過小程式獲取附近的(比如1000米)之類的設備列表,以距離排序

第一個想到的的是找百度/騰訊等地圖,看有沒有提供相應的開放api,先將我們的設備id以及對應的經緯度存儲到地圖中,再調用某個api,傳入我當前坐標經緯度,然後返回附近的設備列表。最後沒找到這個介面。應該是有,但是我沒找到

第二個想能不能通過c#用啥演算法實現,太菜搞不定

最後想到sqlserver有個空間數據的概念,最終勉強實現。

參考:空間數據 (SQL Server) efcore中使用空間數據

 

概述

空間對象其實就是點、線、面之類的意思,我們希望對其進行一些操作,如:查詢得到兩個面之間的交集/差集/並集;以一個點為中心,設置半徑得到一個面;查詢兩個點之間的距離;等等。這些操作如果我們自己用演算法來實現想想有點怕。

c#提供了相應的庫來表示這些空間對象,也提供了相應的方法來執行針對空間對象的操作 ->NetTopologySuite(從java的JTS移植來的)由於這次小需求只是依賴了資料庫對空間數據的支持,所以沒有詳細研究NetTopologySuite(資料少)

sqlserver2008開始支持空間數據,它也提供了相應的類型來表示空間對象,也提供相應的函數來操作這些對象,當然其它數據也支持

估計還有單獨的空間數據引擎,以文檔形式存儲空間對象

這些點/線/面可以放在一個普通平面中,這時把他們看成幾何對象,比如一個點就可以用XY坐標來表示、一個線就可以用兩個點來表示...;

也可以將這些空間對象放在地球環境中來看,那麼點就對象就用經緯度來表示、線就用兩個點來表示

 

幾何圖形與地理位置

同一個空間對象,比如一個點 可以把它放在一個普通的平面坐標中來看待,用XY坐標來表示,也可以放進地球環境中用經緯度來表示。

  1. Geometry 類型表示歐幾裡得(平面)坐標系中的數據。
  2. Geography 類型表示圓形地球坐標系中的數據。

以點來說,可以創建Geometry類型的點,也可以創建Geography類型的點。資料庫和c#都有對象的創建方式。同理 線、面 都分為這兩種類型

空間數據類型

就是說的上面的點、線、面 當然還有更多類型。NetTopologySuite庫提供了相應的類型來表示。sqlserver中也有相應的類型,但是sqlserver存儲空間對象的欄位的類型只分為Geography和Geometry,只是在插入值的時候會創建不同的對象

 

空間引用標識符 (SRID)

文檔的說明看不太懂,反正對我們的限制就是 若我們使用Geography類型的空間對象,那麼必須為每個空間對象設置SRID,對多個空間進行操作(比如看距離)時,這些空間對象的SRID必須一樣。

感覺就像是有多個地球,每個地球有一個編號。同一個點(經緯度)在不同的地球(SRID)中其實位置不一樣。不曉得這樣理解對不。

在當前需求中反正寫死4326,文檔中經常用這個。

 

各種函數

實例方法:一個空間對象就是一個實例。在sql語句中可以實例化一個空間對象,數據表那個存儲空間對象的單元格中存儲的就是一個具體的空間對象實例

靜態方法:不屬於空間對象實例的,通過字元串創建空間對象,這個方法放實例上不合適

其實跟c#中的實例和靜態一個意思

OGC:應該是個什麼標準,定義了空間數據的通用操作,當然分為實例OGC方法和靜態OGC方法

微軟對標準進行了擴展,實例和靜態都有擴展

 

原始SQL和EFCore實現

efcore不熟 又是第一次用空間數據,所以沒用efcore來實現,本身用的abp 預設是用的efcore,用這個方式本來應該更方便。efcore中使用空間數據

原始sql就簡單了。

 

沒有用文檔中的空間索引。也沒有直接存儲空間對象,而是查詢時構建

爛尾....


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概要: C#中將數據類型分為值類型(value type)和引用類型(reference type) 值類型: 值類型變數直接包含其本身的數據。在定義一個值類型變數後,將直接為該變數分配空間,可以直接賦值和使用。 列舉值類型: eg: 用變數“a”為變數“b”賦值,是將“a”所在記憶體的值複製給“b” ...
  • 最近在學習C# Socket相關的知識,學習之餘,動手做了一個簡單的區域網聊天器。有萌生做這個的想法,主要是由於之前家裡兩臺電腦之間想要傳輸文件十分麻煩,需要藉助QQ,微信或者其他第三方應用,基本都要登錄,而且可能傳輸的文件還有大小限制,壓縮問題。所以本聊天器的首要目標就是解決這兩個問題,做到使用方... ...
  • 本文先是對 Polly 做了一個簡單介紹,通過一個例子讓大家知道了 Polly 的基本用法和步驟,然後分別介紹了 Polly 的七種策略。其實 Polly 遠比本文講的要強大,但由於篇幅的限制和精力有限,只能籠統地給大家做個介紹,更多的應用場景還需要結合實際的例子才能講清楚。要深入研究,可以前往查看... ...
  • 在上一篇abp(net core)+easyui+efcore實現倉儲管理系統——入庫管理之三存儲過程(三十九) 文章中我們學習瞭如何在ABP中調用存儲過程並創建相關的類。接下來我們要來實現調用存儲過程,同時實現服務類的編寫。 ...
  • 1、抽象類要被子類繼承,介面要被類實現 2、介面只能做方法聲明,抽象類中可以作方法聲明,也可以做方法實現 3、介面里定義的變數只能是公共的靜態的常量,抽象類中的變數是普通變數 4、介面是設計的結果,抽象類是重構的結果 5、抽象類和介面都是用來抽象具體對象的,但是介面的抽象級別最高 6、抽象類可以有具 ...
  • 利用FlowDocument進行模板列印 xaml 代碼 用String.Replace進行替換,不知道也沒有其他辦法? ...
  • 系統有個欄位,作為參數設置,限制用戶只能輸入大於0的正整數: <input type="text" name="non" ng-model="non" onpaste="return false;" onkeyup="if ( this.value.length == 1 ) { this.valu ...
  • C# 實現向指定郵箱發送信息功能: 應用場景: 可以快速批量或者自動向指定用戶發送模板郵件信息,比如重置密碼時可以向指定郵箱發送驗證碼,公司發佈公告、通知等,由於向郵箱發送驗證碼是免費的,因此可以節約成本。 前提條件: 1、知曉郵箱伺服器的類型,與郵箱伺服器埠。我使用的是QQ郵箱,QQ郵箱的郵箱服 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...