PostgreSQL 常用空间处理函数
1.OGC标准函数
管理函数:
添加几何字段 AddGeometryColumn(, , , , , )
 删除几何字段 DropGeometryColumn(, , )
 检查数据库几何字段并在geometry_columns中归档 Probe_Geometry_Columns()
 给几何对象设置空间参考(在通过一个范围做空间查询时常用)ST_SetSRID(geometry, integer)
几何对象关系函数:
获取两个几何对象间的距离:ST_Distance(geometry, geometry)
 如果两个几何对象间距离在给定值范围内,则返回TRUE:ST_DWithin(geometry, geometry, float)
 判断两个几何对象是否相等(比如LINESTRING(0 0, 2 2)和LINESTRING(0 0, 1 1, 2 2)是相同的几何对象):ST_Equals(geometry, geometry)
 判断两个几何对象是否分离:ST_Disjoint(geometry, geometry)
 判断两个几何对象是否相交:ST_Intersects(geometry, geometry)
 判断两个几何对象的边缘是否接触:ST_Touches(geometry, geometry)
 判断两个几何对象是否互相穿过:ST_Crosses(geometry, geometry)
 判断A是否被B包含:ST_Within(geometry A, geometry B)
 判断两个几何对象是否是重叠:ST_Overlaps(geometry, geometry)
 判断A是否包含B:ST_Contains(geometry A, geometry B)
 判断A是否覆盖 B:ST_Covers(geometry A, geometry B)
 判断A是否被B所覆盖:ST_CoveredBy(geometry A, geometry B)
 通过DE-9IM 矩阵判断两个几何对象的关系是否成立:ST_Relate(geometry, geometry, intersectionPatternMatrix)
 获得两个几何对象的关系(DE-9IM矩阵):ST_Relate(geometry, geometry)
几何对象处理函数:
获取几何对象的中心 ST_Centroid(geometry)
 面积量测 ST_Area(geometry)
 长度量测 ST_Length(geometry)
 返回曲面上的一个点 ST_PointOnSurface(geometry)
 获取边界 ST_Boundary(geometry)
 获取缓冲后的几何对象 ST_Buffer(geometry, double,[integer])
 获取多几何对象的外接对象 ST_ConvexHull(geometry)
 获取两个几何对象相交的部分 ST_Intersection(geometry, geometry)
 将经度小于0的值加360使所有经度值在0-360间 ST_Shift_Longitude(geometry)
 获取两个几何对象不相交的部分(A、B可互换) ST_SymDifference(geometry A,geometry B)
 从A去除和B相交的部分后返回 ST_Difference(geometry A, geometryB)
 返回两个几何对象的合并结果 ST_Union(geometry, geometry)
 返回一系列几何对象的合并结果 ST_Union(geometry set)
 用较少的内存和较长的时间完成合并操作,结果和ST_Union相同 ST_MemUnion(geometry set)
几何对象存取函数:
获取几何对象的WKT描述 ST_AsText(geometry)
 获取几何对象的WKB描述 ST_AsBinary(geometry)
 获取几何对象的空间参考ID ST_SRID(geometry)
 获取几何对象的维数 ST_Dimension(geometry)
 获取几何对象的边界范围 ST_Envelope(geometry)
 判断几何对象是否为空 ST_IsEmpty(geometry)
 判断几何对象是否不包含特殊点(比如自相交)ST_IsSimple(geometry)
 判断几何对象是否闭合 ST_IsClosed(geometry)
 判断曲线是否闭合并且不包含特殊点 ST_IsRing(geometry)
 获取多几何对象中的对象个数 ST_NumGeometries(geometry)
 获取多几何对象中第N个对象 ST_GeometryN(geometry,int)
 获取几何对象中的点个数 ST_NumPoints(geometry)
 获取几何对象的第N个点 ST_PointN(geometry,integer)
 获取多边形的外边缘 ST_ExteriorRing(geometry)
 获取多边形内边界个数 ST_NumInteriorRings(geometry)
 同上 ST_NumInteriorRing(geometry)
 获取多边形的第N个内边界 ST_InteriorRingN(geometry,integer)
 获取线的终点 ST_EndPoint(geometry)
 获取线的起始点 ST_StartPoint(geometry)
 获取几何对象的类型 GeometryType(geometry)
 类似上,但是不检查M值,即POINTM对象会被判断为point ST_GeometryType(geometry)
 获取点的X坐标 ST_X(geometry)
 获取点的Y坐标 ST_Y(geometry)
 获取点的Z坐标 ST_Z(geometry)
 获取点的M值 ST_M(geometry)
几何对象构造函数:
参考语义:
 Text:WKT
 WKB:WKB
 Geom:Geometry
 M:Multi
 Bd:BuildArea
 Coll:Collection ST_GeomFromText(text,[]) 将wkt转为geometry
ST_PointFromText(text,[])
 ST_LineFromText(text,[])
 ST_LinestringFromText(text,[])
 ST_PolyFromText(text,[])
 ST_PolygonFromText(text,[])
 ST_MPointFromText(text,[])
 ST_MLineFromText(text,[])
 ST_MPolyFromText(text,[])
 ST_GeomCollFromText(text,[])
 ST_GeomFromWKB(bytea,[])
 ST_GeometryFromWKB(bytea,[])
 ST_PointFromWKB(bytea,[])
 ST_LineFromWKB(bytea,[])
 ST_LinestringFromWKB(bytea,[])
 ST_PolyFromWKB(bytea,[])
 ST_PolygonFromWKB(bytea,[])
 ST_MPointFromWKB(bytea,[])
 ST_MLineFromWKB(bytea,[])
 ST_MPolyFromWKB(bytea,[])
 ST_GeomCollFromWKB(bytea,[])
 ST_BdPolyFromText(text WKT, integer SRID)
 ST_BdMPolyFromText(text WKT, integer SRID)
2.PostGIS扩展函数
管理函数:
删除一个空间表(包括geometry_columns中的记录) DropGeometryTable([], )
 更新空间表的空间参考 UpdateGeometrySRID([], , , )
 更新空间表的统计信息 update_geometry_stats([, ])
参考语义:
 Geos:GEOS库
 Jts:JTS库
 Proj:PROJ4库
postgis_version()
 postgis_lib_version()
 postgis_lib_build_date()
 postgis_script_build_date()
 postgis_scripts_installed()
 postgis_scripts_released()
 postgis_geos_version()
 postgis_jts_version()
 postgis_proj_version()
 postgis_uses_stats()
 postgis_full_version()
几何操作符:
A范围=B范围 A = B
 A范围覆盖B范围或A范围在B范围左侧 A &<> B
 A范围在B范围左侧 A <<>> B
 A范围覆盖B范围或A范围在B范围下方 A &<| B A范围覆盖B范围或A范围在B范围上方 A |&> B
 A范围在B范围下方 A <<| B A范围在B范围上方 A |>> B
 A=B A ~= B
 A范围被B范围包含 A @ B
 A范围包含B范围 A ~ B
 A范围覆盖B范围 A && B
几何量测函数:
量测面积 ST_Area(geometry)
 根据经纬度点计算在地球曲面上的距离,单位米,地球半径取值6370986米 ST_distance_sphere(point, point)
 类似上,使用指定的地球椭球参数 ST_distance_spheroid(point, point, spheroid)
 量测2D对象长度 ST_length2d(geometry)
 量测3D对象长度 ST_length3d(geometry)
 根据经纬度对象计算在地球曲面上的长度 ST_length_spheroid(geometry,spheroid)
 ST_length3d_spheroid(geometry,spheroid)
 量测两个对象间距离 ST_distance(geometry, geometry)
 量测两条线之间的最大距离 ST_max_distance(linestring,linestring)
 量测2D对象的周长 ST_perimeter(geometry)
 ST_perimeter2d(geometry)
 量测3D对象的周长 ST_perimeter3d(geometry)
 量测两点构成的方位角,单位弧度 ST_azimuth(geometry, geometry)
几何对象输出:
参考语义:
 NDR:Little Endian
 XDR:big-endian
 HEXEWKB:Canonical
 SVG:SVG 格式
 GML:GML 格式
 KML:KML 格式
GeoJson:GeoJson 格式
 ST_AsBinary(geometry,{‘NDR’|‘XDR’})
 ST_AsEWKT(geometry)
 ST_AsEWKB(geometry, {‘NDR’|‘XDR’})
 ST_AsHEXEWKB(geometry, {‘NDR’|‘XDR’})
 ST_AsSVG(geometry, [rel], [precision])
 ST_AsGML([version], geometry, [precision])
 ST_AsKML([version], geometry, [precision])
 ST_AsGeoJson([version], geometry, [precision], [options])
几何对象创建:
参考语义:
 Dump:转储
ST_GeomFromEWKT(text)
 ST_GeomFromEWKB(bytea)
 ST_MakePoint(, , [], [])
 ST_MakePointM(, , )
 ST_MakeBox2D(, )
 ST_MakeBox3D(, )
 ST_MakeLine(geometry set)
 ST_MakeLine(geometry, geometry)
 ST_LineFromMultiPoint(multipoint)
 ST_MakePolygon(linestring, [linestring[]])
 ST_BuildArea(geometry)
 ST_Polygonize(geometry set)
 ST_Collect(geometry set)
 ST_Collect(geometry, geometry)
 ST_Dump(geometry)
 ST_DumpRings(geometry)
几何对象编辑:
给几何对象添加一个边界,会使查询速度加快 ST_AddBBOX(geometry)
 删除几何对象的边界 ST_DropBBOX(geometry)
 添加、删除、设置点 ST_AddPoint(linestring, point, [])
 ST_RemovePoint(linestring, offset)
 ST_SetPoint(linestring, N, point)
 几何对象类型转换 ST_Force_collection(geometry)
 ST_Force_2d(geometry)
 ST_Force_3dz(geometry), ST_Force_3d(geometry),
 ST_Force_3dm(geometry)
 ST_Force_4d(geometry)
 ST_Multi(geometry)
 将几何对象转化到指定空间参考 ST_Transform(geometry,integer)
 对3D几何对象作仿射变化 ST_Affine(geometry, float8, float8, float8, float8, float8, float8, float8, float8, float8, float8, float8, float8)
 对2D几何对象作仿射变化 ST_Affine(geometry, float8, float8, float8, float8, float8, float8)
 对几何对象作偏移 ST_Translate(geometry, float8, float8, float8)
 对几何对象作缩放 ST_Scale(geometry, float8, float8, float8)
 对3D几何对象作旋转 ST_RotateZ(geometry, float8)
 ST_RotateX(geometry, float8)
 ST_RotateY(geometry, float8)
 对2D对象作偏移和缩放 ST_TransScale(geometry, float8, float8, float8, float8)
 反转 ST_Reverse(geometry)
 转化到右手定则 ST_ForceRHR(geometry)
 参考IsSimple函数
 使用Douglas-Peuker算法 ST_Simplify(geometry, tolerance)
 ST_SimplifyPreserveTopology(geometry, tolerance)
 讲几何对象顶点捕捉到网格 ST_SnapToGrid(geometry, originX, originY, sizeX, sizeY)
 ST_SnapToGrid(geometry, sizeX, sizeY), ST_SnapToGrid(geometry, size)
 第二个参数为点,指定原点坐标 ST_SnapToGrid(geometry, geometry, sizeX, sizeY, sizeZ, sizeM)
 分段 ST_Segmentize(geometry, maxlength)
 合并为线 ST_LineMerge(geometry)
线性参考:
根据location(0-1)获得该位置的点 ST_line_interpolate_point(linestring, location)
 获取一段线 ST_line_substring(linestring, start, end)
 根据点获取location(0-1) ST_line_locate_point(LineString, Point)
 根据量测值获得几何对象 ST_locate_along_measure(geometry, float8)
 根据量测值区间获得几何对象集合 ST_locate_between_measures(geometry, float8, float8)
杂项功能函数:
几何对象的摘要 ST_Summary(geometry)
 几何对象的边界 ST_box2d(geometry)
 ST_box3d(geometry)
 多个几何对象的边界 ST_extent(geometry set)
 0=2d, 1=3dm, 2=3dz, 3=4d ST_zmflag(geometry)
 是否包含Bounding Box ST_HasBBOX(geometry)
 几何对象的维数:2、3、4 ST_ndims(geometry)
 子对象的个数 ST_nrings(geometry)
 ST_npoints(geometry)
 对象是否验证成功 ST_isvalid(geometry)
 扩大几何对象 ST_expand(geometry, float)
 计算一个空间表的边界范围 ST_estimated_extent([schema], table, geocolumn)
 获得空间参考 ST_find_srid(, , )
 几何对象使用的内存大小,单位byte ST_mem_size(geometry)
 点是否在圆上 ST_point_inside_circle(,)
 获取边界的X、Y、Z ST_XMin(box3d)
 ST_YMin(box3d)
 ST_ZMin(box3d)
 ST_XMax(box3d)
 ST_YMax(box3d)
 ST_ZMax(box3d)
 构造一个几何对象的数组 ST_Accum(geometry set)
长事务支持:
启用/关闭长事务支持,重复调用无副作用 EnableLongTransactions() 、DisableLongTransactions()
 检查对行的update和delete操作是否已授权 CheckAuth([], , )
 锁定行 LockRow([], , , , [])
 解锁行 UnlockRows()
 在当前事务中添加授权ID AddAuth()
参考
 其他的函数还有可以到官网进行查看:PostGIS参考官网
相关文章:
PostgreSQL 常用空间处理函数
1.OGC标准函数 管理函数: 添加几何字段 AddGeometryColumn(, , , , , ) 删除几何字段 DropGeometryColumn(, , ) 检查数据库几何字段并在geometry_columns中归档 Probe_Geometry_Columns() 给几何对象设置空间参考(在通过一个范围做空间查询时常用&…...
 
ubuntu初始化/修改root密码
1.登录ubuntu后,使用sudo passwd root命令,进行root密码的初始化/修改,注:这里需要保证两次输入的密码都是同一个,才可成功 ubuntugt-ubuntu22-04-cmd-v1-0-32gb-100m:~/ocr$ sudo passwd root New password: Retype…...
 
【Linux后端服务器开发】select多路转接IO服务器
目录 一、高级IO 二、fcntl 三、select函数接口 四、select实现多路转接IO服务器 一、高级IO 在介绍五种IO模型之前,我们先讲解一个钓鱼例子。 有一条大河,河里有很多鱼,分布均匀。张三是一个钓鱼新手,他钓鱼的时候很紧张&a…...
 
支持向量机(iris)
代码: import pandas as pd from sklearn.preprocessing import StandardScaler from sklearn import svm import numpy as np# 定义每一列的属性 colnames [sepal-length, sepal-width, petal-length, petal-width, class] # 读取数据 iris pd.read_csv(data\\i…...
 
24考研数据结构-第二章:线性表
目录 第二章:线性表2.1线性表的定义(逻辑结构)2.2 线性表的基本操作(运算)2.3 线性表的物理/存储结构(确定了才确定数据结构)2.3.1 顺序表的定义2.3.1.1 静态分配2.3.1.2 动态分配2.3.1.3 mallo…...
Mybatis 动态 sql 是做什么的?都有哪些动态 sql?能简述动态 sql 的执行原理不?
OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性,它旨在提供一个更高的更抽象的层次来对Java对象图进行导航。 OGNL表达式的基本单位是"导航链"&a…...
250_C++_typedef std::function<int(std::vector<int> vtBits)> fnChkSstStt
假设我们需要定义一个函数类型来表示一个能够计算整数向量中所有元素之和的函数。 首先,我们定义一个函数,它的参数是一个 std::vector 类型的整数向量,返回值是 int 类型,表示所有元素之和: int sumVectorElements(std::vector<int> vt) {int sum = 0;for (int n…...
 
无涯教程-jQuery - Transfer方法函数
Transfer 效果可以与effect()方法一起使用。这会将元素的轮廓转移到另一个元素。尝试可视化两个元素之间的交互时非常有用。 Transfer - 语法 selector.effect( "transfer", {arguments}, speed ); 这是所有参数的描述- className - 传输元素将收到的可选类名。…...
 
openGauss学习笔记-24 openGauss 简单数据管理-模式匹配操作符
文章目录 openGauss学习笔记-24 openGauss 简单数据管理-模式匹配操作符24.1 LIKE24.2 SIMILAR TO24.3 POSIX正则表达式 openGauss学习笔记-24 openGauss 简单数据管理-模式匹配操作符 数据库提供了三种独立的实现模式匹配的方法:SQL LIKE操作符、SIMILAR TO操作符…...
 
JAVASE---数据类型与变量
1. 字面常量 常量即程序运行期间,固定不变的量称为常量,比如:一个礼拜七天,一年12个月等。 public class Demo{ public static void main(String[] args){ System.Out.println("hello world!"); System.Out.println(…...
 
IDEA Groovy 脚本一键生成实体类<mybatisplus>
配置数据库(mysql) 一键生成(右键点击table) 配置自己的groovy脚本 import com.intellij.database.model.DasTable import com.intellij.database.util.Case import com.intellij.database.util.DasUtil import com.intellij.data…...
 
无涯教程-jQuery - Puff方法函数
吹气效果可以与show/hide/toggle一起使用。通过按比例放大元素并同时隐藏它,可以形成粉扑效果。 Puff - 语法 selector.hide|show|toggle( "puff", {arguments}, speed ); 这是所有参数的描述- model - 效果的模式。可以是"显…...
 
什么叫前后端分离?为什么需要前后端问题?解决了什么问题?
单体架构出现的问题 引出:来看一个单体项目架构的结构 通过上述可以看到单体架构主要存在以下几点问题: 开发人员同时负责前端和后端代码开发,分工不明确开发效率低前后端代码混合在一个工程中,不便于管理对开发人员要求高(既会前…...
Vector<T> 动态数组(随机访问迭代器)(答案)
答案如下 //------下面的代码是用来测试你的代码有没有问题的辅助代码,你无需关注------ #include <algorithm> #include <cstdlib> #include <iostream> #include <vector> #include <utility> using namespace std; struct Record { Record…...
 
Istio 故障注入与重试的实验
故障注入 Istio流量治理有故障注入的功能,在接收到用户请求程序的流量时,注入故障现象,例如注入HTTP请求错误,当有流量进入Sidecar时,直接返回一个500的错误请求代码。 通过故障注入可以用来测试整个应用程序的故障恢…...
Java设计模式-中介者模式
中介者模式 1.中介者模式含义 中介者模式,就是用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地互相引用,从而使其耦合松散,而且可以独立的改变它们之间的交互。 其实中介者模式很简单的,就像它的名字一样&a…...
 
OpenCV实现高斯模糊加水印
# coding:utf-8 # Email: wangguisendonews.com # Time: 2023/4/21 10:07 # File: utils.pyimport cv2 import PIL from PIL import Image import numpy as np from watermarker.marker import add_mark, im_add_mark import matplotlib.pyplot as plt# PIL Image转换成OpenCV格…...
 
JMeter 怎么查看 TPS 数据教程,简单易懂
TPS 是软件测试结果的测量单位。一个事务是指一个客户机向服务器发送请求然后服务器做出反应的过程。客户机在发送请求时开始计时,收到服务器响应后结束计时,以此来计算使用的时间和完成的事务个数。在 JMeter 中,我们可以使用以下方法查看 T…...
 
2023年的深度学习入门指南(19) - LLaMA 2源码解析
2023年的深度学习入门指南(19) - LLaMA 2源码解析 上一节我们学习了LLaMA 2的补全和聊天两种API的使用方法。本节我们来看看LLaMA 2的源码。 补全函数text_completion源码解析 上一节我们讲了LLaMA 2的编程方法。我们来复习一下: generator Llama.build(ckpt_di…...
慕课网Go-2.数组、slice、map、list
数组 package mainimport "fmt"func main() {var course1 [3]stringcourse1[0] "go"course1[1] "grpc"course1[2] "gin"for _, value : range course1 {fmt.Println(value)}course2 : [3]string{2: "grpc"}fmt.Println(…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
CVPR 2025 MIMO: 支持视觉指代和像素grounding 的医学视觉语言模型
CVPR 2025 | MIMO:支持视觉指代和像素对齐的医学视觉语言模型 论文信息 标题:MIMO: A medical vision language model with visual referring multimodal input and pixel grounding multimodal output作者:Yanyuan Chen, Dexuan Xu, Yu Hu…...
 
(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...
 
shell脚本--常见案例
1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...
 
dedecms 织梦自定义表单留言增加ajax验证码功能
增加ajax功能模块,用户不点击提交按钮,只要输入框失去焦点,就会提前提示验证码是否正确。 一,模板上增加验证码 <input name"vdcode"id"vdcode" placeholder"请输入验证码" type"text&quo…...
 
Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
 
Keil 中设置 STM32 Flash 和 RAM 地址详解
文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...
Java + Spring Boot + Mybatis 实现批量插入
在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法:使用 MyBatis 的 <foreach> 标签和批处理模式(ExecutorType.BATCH)。 方法一:使用 XML 的 <foreach> 标签ÿ…...
PAN/FPN
import torch import torch.nn as nn import torch.nn.functional as F import mathclass LowResQueryHighResKVAttention(nn.Module):"""方案 1: 低分辨率特征 (Query) 查询高分辨率特征 (Key, Value).输出分辨率与低分辨率输入相同。"""def __…...
 
云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
