前言

一个小需求的实现,做一个备忘,个人理解,可能存在错误。

客户有很多设备,这些设备分散在不同的地方,现在需要通过小程序获取附近的(比如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就简单了。

没有用文档中的空间索引。也没有直接存储空间对象,而是查询时构建

烂尾....

sqlserver空间数据 + c# 实现查询附近的设备的更多相关文章

  1. 【SqlServer系列】子查询

    1   概述 1.1  已发布[SqlServer系列]文章 [SqlServer系列]SQLSERVER安装教程 [SqlServer系列]数据库三大范式 [SqlServer系列]表单查询 [Sq ...

  2. 【转载】C#常用数据库Sqlserver通过SQL语句查询数据库以及表的大小

    在Sqlserver数据库中,一般我们查看数据库的大小可以通过查找到数据库文件来查看,但如果要查找数据表Table的大小的话,则不可通过此方法,在Sqlserver数据库中,提供了相应的SQL语句来查 ...

  3. OpenCL 查询平台和设备

    ▶ 查询平台和设备的代码以结果,放在这里方便以后逐渐扩充和查询(没有营养) #include <stdio.h> #include <stdlib.h> #include &l ...

  4. PowerDesigner创建表 拷贝创建表语句 SQLSERVER创建数据库 使用查询 创建表 并且添加数据

    PowerDesigner创建表 : 1.双击打开PowerDesigner   2.双击打开Create model 3左键点击Model  types,再点击Physical    Data  m ...

  5. SQLServer数据库之连接查询

    SQLServer数据库之连接查询 表的连接查询的几种方法介绍: inner join on内连接,left join on 左连接 , rigth join on 右连接, full join on ...

  6. c#程序如何从海康ipserver查询获取DVR设备ip地址

    海康威视提供的ipserver可以记录DVR设备的IP地址,并提供一个7071的端口给客户端查询用,我们在c#程序中可以用海康SDK包中的NET_DVR_GetDVRIPByResolveSvr函数来 ...

  7. 关于SQLSERVER中用SQL语句查询的一些个人理解

    作为一个编程菜鸟说真的很难有什么见解,也就是写给一些刚学习编程的人,希望能给他们一些帮助吧! SQLSERVER作为刚开始入门学习的数据库,SQL语句也并不算太难!说白了也就是建库,建表,建约束,对数 ...

  8. SqlServer性能优化 即席查询(十三)

    执行计划,查询类别: 1.即席查询     2.预定义查询 select c.EnglishProductCategoryName,p.EnglishProductName,p.Color,p.Siz ...

  9. Java如何连接SQLServer,并实现查询、修改、删除方法

    场景:A:在UI自动化时,删除数据时候,在界面UI提示“该XX已被使用,无法删除”. 这时候我们有需要做数据初始化的操作,需要把历史数据做删除,来确脚本运行的重复执行,和稳定性质. B: 在做新增操作 ...

  10. sqlserver 2005范例代码查询辞典文摘

    第1章 select 1.显示指定想要获取的列要比使用select *更好 2.where not m.MemberCode = 1000 3.select * into aaa from Membe ...

随机推荐

  1. Ubuntu 22.04 LTS 在线/离线安装 Docker

    Docker 安装方式 时间:2024-10 准备环境 root@ubuntu2204:~# hostnamectl Static hostname: ubuntu2204 Icon name: co ...

  2. mysql 备份还原命令备忘

    1.备份 mysqldump -u username -p databasename tableName > backupfile.sql 2.还原 mysql -u username -p p ...

  3. 3.10 Linux创建目录(mkdir命令)

    mkdir 命令,是 make directories 的缩写,用于创建新目录,此命令所有用户都可以使用. mkdir 命令的基本格式为: [root@localhost ~]# mkdir [-mp ...

  4. Maven简单介绍——必要的Java管理与构建

    概念 通常Java的项目中有很多的环境和规范的问题,比如一些需要依赖的包,整个项目的目录标准是怎么样的,什么样的文件放在哪个目录等,还有jdk版本,编译代码流程,项目版本号之类的问题. 虽然这些都是小 ...

  5. ubuntu系统安装wps后语言是英文的问题

    如果安装ubuntu系统后,在里面安装wps的时候,发现都是英文,无法切换为中文,可以这样操作. 此时点击这里新建一个word空白文档 点击这里新建文档 点击这里显示语言 点击下面的 简体中文 再点击 ...

  6. npm 发包命令

    npm publish 此命令发布latest版本 npm publish --tag=alpha 发布alpha版本(测试版本)       紧急回退包方案: 分享一下bnpm给的处理方案 如果因为 ...

  7. ElementUI Select单选切换多选无法清除历史数据的解决方案

    背景: 有一个tab切换,每一个tab下都有一个 下拉框,只是一个是多选一个是单选,问题是当切换tab标签的时候,下拉框的样式不会被清空. 解决方案: 只需要在 el-select 上加一个 key ...

  8. json数据按照某一个相同键值进行分类成一个新的二维json数组

    1 formatTreeData(checkNodes){ 2 var map = {}, 3 targetData = []; 4 checkNodes.forEach(item => { 5 ...

  9. 【Spring】IOC核心源码学习(二):容器初始化过程

    接上文 啃啃老菜: Spring IOC核心源码学习(一) ,本文将以 ClassPathXmlApplicationContext 这个容器的实现作为基础,学习容器的初始化过程. ClassPath ...

  10. Java语言的动态性支持

    一.脚本语言的支持     JSR 223中规范了在Java虚拟机上运行的脚本语言与Java程序之间的交互方式.JSR 233是JavaSE6的一部分,在Java表中API中的包是javax.scri ...