postgresql----几何类型和函数

postgresql支持的几何类型如下表:

名字 存储空间 描述 表现形式
point 16字节 平面上的点 (x,y)
line 32字节 直线 {A,B,C}
lseg 32字节 线段 ((x1,y1),(x2,y2))
box 32字节 矩形 ((x1,y1),(x2,y2))
path 16+16n字节 闭合路径 ((x1,y1),...)
path 16+16n字节 开放路径 [(x1,y1),...]
polygon 40+16n字节 多边形 ((x1,y1),...)
circle 24字节 <(x,y),r> 

示例:

test=# select point‘(1,1)‘;
 point
-------
 (1,1)
(1 row)

test=# select line‘{1,1,1}‘;
  line
---------
 {1,1,1}
(1 row)

test=# select lseg‘(1,1),(2,2)‘;
     lseg
---------------
 [(1,1),(2,2)]
(1 row)

test=# select box‘(1,1),(2,2)‘;
     box
-------------
 (2,2),(1,1)
(1 row)

test=# select path‘(1,1),(2,2),(2,1)‘;
        path
---------------------
 ((1,1),(2,2),(2,1))
(1 row)

test=# select path‘[(1,1),(2,2),(2,1)]‘;
        path
---------------------
 [(1,1),(2,2),(2,1)]
(1 row)

test=# select polygon‘((1,1),(2,2),(2,1))‘;
       polygon
---------------------
 ((1,1),(2,2),(2,1))
(1 row)

test=# select circle‘<(0,0),1>‘;
  circle
-----------
 <(0,0),1>
(1 row)

操作符

操作符 描述 示例 结果
+ 平移 select box ‘((0,0),(1,1))‘ + point ‘(2.0,0)‘; (3,1),(2,0)
- 平移 select box ‘((0,0),(1,1))‘ - point ‘(2.0,0)‘; (-1,1),(-2,0)
* 伸缩/旋转 select box ‘((0,0),(1,1))‘ * point ‘(2.0,0)‘; (2,2),(0,0)
/ 伸缩/旋转 select box ‘((0,0),(2,2))‘ / point ‘(2.0,0)‘; (1,1),(0,0)
# 交点或者交面 select box‘((1,-1),(-1,1))‘ # box‘((1,1),(-1,-1))‘; (1,1),(-1,-1)
# path或polygon的顶点数 select #path‘((1,1),(2,2),(2,1))‘; 3
@[email protected] 长度或周长 select @[email protected] path‘((1,1),(2,2),(2,1))‘; 3.41421356237309
@@ 中心 select @@ circle‘<(0,0),1>‘; (0,0)
## 第一个操作数和第二个操作数的最近点 select point ‘(0,0)‘ ## lseg ‘((2,0),(0,2))‘; (1,1)
<-> 间距 select circle ‘<(0,0),1>‘ <-> circle ‘<(5,0),1>‘; 3
&& 是否有重叠 select box ‘((0,0),(1,1))‘ && box ‘((0,0),(2,2))‘; t
<< 是否严格在左 select circle ‘((0,0),1)‘ << circle ‘((5,0),1)‘; t
>> 是否严格在右 select circle ‘((0,0),1)‘ >> circle ‘((5,0),1)‘; f
&< 是否没有延伸到右边 select box ‘((0,0),(1,1))‘ &< box ‘((0,0),(2,2))‘; t
&> 是否没有延伸到左边 select box ‘((0,0),(3,3))‘ &> box ‘((0,0),(2,2))‘; t
<<| 是否严格在下 select box ‘((0,0),(3,3))‘ <<| box ‘((3,4),(5,5))‘; t
|>> 是否严格在上 select box ‘((3,4),(5,5))‘ |>> box ‘((0,0),(3,3))‘; t
&<| 是否没有延伸到上面 select box ‘((0,0),(1,1))‘ &<| box ‘((0,0),(2,2))‘; t
|&> 是否没有延伸到下面 select box ‘((0,0),(3,3))‘ |&> box ‘((0,0),(2,2))‘; t
<^ 是否低于(允许接触) select box ‘((0,0),(3,3))‘ <^ box ‘((3,3),(4,4))‘; t
>^ 是否高于(允许接触) select box ‘((0,0),(3,3))‘ >^ box ‘((3,3),(4,4))‘; f
?# 是否相交 select lseg ‘((-1,0),(1,0))‘ ?# box ‘((-2,-2),(2,2))‘; t
?- 是否水平对齐 select ?- lseg ‘((-1,1),(1,1))‘; t
?- 两边图形是否水平对齐 select point ‘(1,0)‘ ?- point ‘(0,0)‘; t
?| 是否竖直对齐 select ?| lseg ‘((-1,0),(1,0))‘; f
?| 两边图形是否竖直对齐 select point ‘(0,1)‘ ?| point ‘(0,0)‘; t
?-| 是否垂直 select lseg ‘((0,0),(0,1))‘ ?-| lseg ‘((0,0),(1,0))‘; t
?|| 是否平行 select lseg ‘((-1,0),(1,0))‘ ?|| lseg ‘((-1,2),(1,2))‘; t
@> 是否包含 select circle ‘((0,0),2)‘ @> point ‘(1,1)‘; t
<@ 是否包含于或在图形上 select point ‘(1,1)‘ <@ circle ‘((0,0),2)‘; t
~= 是否相同 select polygon ‘((0,0),(1,1))‘ ~= polygon ‘((1,1),(0,0))‘; t

函数

函数 返回值类型 描述 示例 结果
area(object) double precision 面积 select area(circle‘((0,0),1)‘); 3.14159265358979
center(object) point 中心 select center(box‘(0,0),(1,1)‘); (0.5,0.5)
diameter(circle) double precision 圆周长 select diameter(circle ‘((0,0),2.0)‘); 4
height(box) double precision 矩形竖直高度 select height(box ‘((0,0),(1,1))‘); 1
isclosed(path) boolean 是否为闭合路径 select isclosed(path ‘((0,0),(1,1),(2,0))‘); t
isopen(path) boolean 是否为开放路径 select isopen(path ‘[(0,0),(1,1),(2,0)]‘); t
length(object) double precision 长度 select length(path ‘((-1,0),(1,0))‘); 4
npoints(path) int path中的顶点数 select npoints(path ‘[(0,0),(1,1),(2,0)]‘); 3
npoints(polygon) int 多边形的顶点数 select npoints(polygon ‘((1,1),(0,0))‘); 2
pclose(path) path 将开放path转换为闭合path select pclose(path ‘[(0,0),(1,1),(2,0)]‘);  ((0,0),(1,1),(2,0))
popen(path) path 将闭合path转换为开放path select popen(path ‘((0,0),(1,1),(2,0))‘); [(0,0),(1,1),(2,0)]
radius(circle) double precision 圆半径 select radius(circle ‘((0,0),2.0)‘); 2
width(box) double precision 矩形的水平长度 select width(box ‘((0,0),(1,1))‘); 1

类型转换函数

函数 返回类型 描述 示例 结果
box(circle) box 圆形转矩形 select box(circle ‘((0,0),2.0)‘); (1.41421356237309,1.41421356237309),(-1.41421356237309,-1.41421356237309)
box(point) box 点转空矩形 select box(point ‘(0,0)‘); (0,0),(0,0)
box(pointpoint) box 点转矩形 select box(point ‘(0,0)‘, point ‘(1,1)‘); (1,1),(0,0)
box(polygon) box 多边形转矩形 select box(polygon ‘((0,0),(1,1),(2,0))‘); (2,1),(0,0)
bound_box(boxbox) box 将两个矩形转换成一个边界矩形 select bound_box(box ‘((0,0),(1,1))‘, box ‘((3,3),(4,4))‘); (4,4),(0,0)
circle(box) circle 矩形转圆形 select circle(box ‘((0,0),(1,1))‘); <(0.5,0.5),0.707106781186548>
circle(pointdouble precision) circle 圆心与半径转圆形 select circle(point ‘(0,0)‘, 2.0); <(0,0),2>
circle(polygon) circle 多边形转圆形 select circle(polygon ‘((0,0),(1,1),(2,0))‘); <(1,0.333333333333333),0.924950591148529>
line(pointpoint) line 点转直线 select line(point ‘(-1,0)‘, point ‘(1,0)‘); {0,-1,0}
lseg(box) lseg 矩形转线段 select lseg(box ‘((-1,0),(1,0))‘); [(1,0),(-1,0)]
lseg(pointpoint) lseg 点转线段 select lseg(point ‘(-1,0)‘, point ‘(1,0)‘); [(-1,0),(1,0)]
path(polygon) path 多边形转path select path(polygon ‘((0,0),(1,1),(2,0))‘); ((0,0),(1,1),(2,0))
point(double precisiondouble precision) point select point(23.4, -44.5); (23.4,-44.5)
point(box) point 矩形转点 select point(box ‘((-1,0),(1,0))‘); (0,0)
point(circle) point 圆心 select point(circle ‘((0,0),2.0)‘); (0,0)
point(lseg) point 线段中心 select point(lseg ‘((-1,0),(1,0))‘); (0,0)
point(polygon) point 多边形的中心 select point(polygon ‘((0,0),(1,1),(2,0))‘); (1,0.333333333333333)
polygon(box) polygon 矩形转4点多边形 select polygon(box ‘((0,0),(1,1))‘); ((0,0),(0,1),(1,1),(1,0))
polygon(circle) polygon 圆形转12点多边形 select polygon(circle ‘((0,0),2.0)‘);
((-2,0),(-1.73205080756888,1),(-1,1.73205080756888),(-1.22460635382238e-16,2),(1,1.73205080756888),(1.73205080756888,1),(2,2.4492127
0764475e-16),(1.73205080756888,-0.999999999999999),(1,-1.73205080756888),(3.67381906146713e-16,-2),(-0.999999999999999,-1.73205080756
888),(-1.73205080756888,-1))

polygon(nptscircle) polygon 圆形转npts点多边形 select polygon(12, circle ‘((0,0),2.0)‘);
((-2,0),(-1.73205080756888,1),(-1,1.73205080756888),(-1.22460635382238e-16,2),(1,1.73205080756888),(1.73205080756888,1),(2,2.4492127
0764475e-16),(1.73205080756888,-0.999999999999999),(1,-1.73205080756888),(3.67381906146713e-16,-2),(-0.999999999999999,-1.73205080756
888),(-1.73205080756888,-1))

polygon(path) polygon 将path转多边形 select polygon(path ‘((0,0),(1,1),(2,0))‘); ((0,0),(1,1),(2,0))

原文链接:

https://www.postgresql.org/docs/9.6/static/functions-geometry.html

如果有兴趣学习地图相关的,大家可以去看一下postgis。

时间: 2024-10-10 09:04:47

postgresql----几何类型和函数的相关文章

PostgreSQL学习手册(五) 函数和操作符

PostgreSQL学习手册(五) 函数和操作符 一.逻辑操作符:    常用的逻辑操作符有:AND.OR和NOT.其语义与其它编程语言中的逻辑操作符完全相同. 二.比较操作符:    下面是PostgreSQL中提供的比较操作符列表: 操作符 描述 < 小于 > 大于 <= 小于或等于 >= 大于或等于 = 等于 != 不等于 比较操作符可以用于所有可以比较的数据类型.所有比较操作符都是双目操作符,且返回boolean类型.除了比较操作符以外,我们还可以使用BETWEEN语句,如

postgresql 数组类型初步实践

实践环境 数据库:postgresql 9.4:操作系统:windows 创建包含数组类型的数据库 注意在设置default 值时(当然你可以不指定默认值),要声明数组的类型,像这样声明"::bigint[]". create table testarray( id serial primary key, images bigint[] default array[]::bigint[] ); 插入数组值 注意插入数组时,也要声明数组的类型,同上 insert into testarr

PostgreSQL的时间/日期函数使用

PostgreSQL的常用时间函数使用整理如下: 一.获取系统时间函数 1.1 获取当前完整时间 select now(); david=# select now(); now ------------------------------- 2013-04-12 15:39:40.399711+08 (1 row) david=# current_timestamp 同 now() 函数等效. david=# select current_timestamp; now -------------

[转帖]PostgreSQL的时间/日期函数使用

https://www.cnblogs.com/mchina/archive/2013/04/15/3010418.html 这个博客的 文章目录比上一个好十倍 另外interval 之前的必须加 之后的时间可以不用加 勒了个擦的. PostgreSQL的常用时间函数使用整理如下: 一.获取系统时间函数 1.1 获取当前完整时间 select now(); david=# select now(); now ------------------------------- 2013-04-12 1

C++数组类型与函数类型

之所以将C++的数组类型与函数类型拿到一块说,是因为两者在很多地方都一样. 首先,声明形式上类似: 数组类型:  type [num]                                          数组:type name[num] 函数类型:  return_type (形参列表)    函数:return_type name(形参列表) 数组指针类型: type (*)[num] 数组指针:type (*name)[num] 函数指针类型: return_type (*)

基类中定义的虚函数在派生类中重新定义时,其函数原型,包括返回类型、函数名、参数个数、参数类型及参数的先后顺序,都必须与基类中的原型完全相同 but------&gt; 可以返回派生类对象的引用或指针

您查询的关键词是:c++primer习题15.25 以下是该网页在北京时间 2016年07月15日 02:57:08 的快照: 如果打开速度慢,可以尝试快速版:如果想更新或删除快照,可以投诉快照. 百度和网页 http://bbs.csdn.net/topics/380238133 的作者无关,不对其内容负责.百度快照谨为网络故障时之索引,不代表被搜索网站的即时页面. 首页 精选版块 移动开发 iOS Android Qt WP 云计算 IaaS Pass/SaaS 分布式计算/Hadoop J

教你几何画板绝对值函数怎样画

几何画板是一些数学爱好者经常使用的作图工具,利用几何画板能够很准确的画出自己想要画出的函数图像,可是有的时候函数解析式中带有了绝对值,这样的几何画板绝对值函数图像怎样画呢? 具体步骤如下: 在几何画板窗口中,选择“绘图”——“绘制新函数”. 输入函数解析式,例如f(x)=|cosx|,在新建函数窗口中选择“函数”按钮,在下拉菜单中选择“abs”函数. 确定后绘图区域自动出现函数图象,如图所示. 以上内容向大家介绍了几何画板绝对值函数的绘制方法,操作简单.绝对值函数是几何画板函数功能中默认的一种,

PHP常用类型判断函数

1.gettype():获取变量类型 2.is_array():判断变量类型是否为数组类型 3.is_double():判断变量类型是否为倍浮点类型 4.is_float():判断变量类型是否为浮点类型 5.is_int():判断变量类型是否为整数类型 6.is_integer():判断变量类型是否为长整数类型 7.is_long():判断变量类型是否为长整数类型 8.is_object():判断变量类型是否为对象类型 9.is_real(): 判断变量类型是否为实数类型 10.is_strin

C函数类型和函数指针使用方法详解

二.通常的函数调用 一个通常的函数调用的例子: /* 自行包含头文件 */ void MyFun(int x); /* 此处的声明也可写成:void MyFun(int) */ int main(int argc, char* argv[]) {    MyFun(10); /* 这里是调用MyFun(10) 函数 */    return(0); } void MyFun(int x) /* 这里定义一个MyFun函数 */ {    printf("%d\n",x); } 这个My