point (点)、box (矩形)、 lseg、line (線分)、path (道)、 polygon (多角形)、およびcircle (円) データ型は PostgreSQL が元もとサポートしている関数と演算子が豊富に揃っています。
Table 4-18. Geometric Operators
演算子 | 説明 | 使用法 |
---|---|---|
+ | 並行移動 | box '((0,0),(1,1))' + point '(2.0,0)' |
- | 並行移動 | box '((0,0),(1,1))' - point '(2.0,0)' |
* | 縮尺/回転 | box '((0,0),(1,1))' * point '(2.0,0)' |
/ | 縮尺/回転 | box '((0,0),(2,2))' / point '(2.0,0)' |
# | 交差 | '((1,-1),(-1,1))' # '((1,1),(-1,-1))' |
# | 多角形の頂点数 | # '((1,0),(0,1),(-1,0))' |
## | 近接点 | point '(0,0)' ## lseg '((2,0),(0,2))' |
&& | 重なり? | box '((0,0),(1,1))' && box '((0,0),(2,2))' |
&< | 左側に重なり? | box '((0,0),(1,1))' &< box '((0,0),(2,2))' |
&> | 右側に重なり? | box '((0,0),(3,3))' &> box '((0,0),(2,2))' |
<-> | 距離 | circle '((0,0),1)' <-> circle '((5,0),1)' |
<< | 左? | circle '((0,0),1)' << circle '((5,0),1)' |
<^ | 下? | circle '((0,0),1)' <^ circle '((0,5),1)' |
>> | 右? | circle '((5,0),1)' >> circle '((0,0),1)' |
>^ | 上? | circle '((0,5),1)' >^ circle '((0,0),1)' |
?# | 交差か重なり | lseg '((-1,0),(1,0))' ?# box '((-2,-2),(2,2))' |
?- | 水平? | point '(1,0)' ?- point '(0,0)' |
?-| | 直交? | lseg '((0,0),(0,1))' ?-| lseg '((0,0),(1,0))' |
@-@ | 長さ、あるいは円周 | @-@ path '((0,0),(1,0))' |
?| | 垂直? | point '(0,1)' ?| point '(0,0)' |
?|| | 並行? | lseg '((-1,0),(1,0))' ?|| lseg '((-1,2),(1,2))' |
@ | 内包、あるいは上層 | point '(1,1)' @ circle '((0,0),2)' |
@@ | 中心 | @@ circle '((0,0),10)' |
~= | 等しい | polygon '((0,0),(1,1))' ~= polygon '((1,1),(0,0))' |
Table 4-19. 幾何関数
関数 | 返り値 | 説明 | 例 |
---|---|---|---|
area(object) | double precision (倍精度) | 要素の面積 | area(box '((0,0),(1,1))') |
box(box, box) | box (矩形) | 矩形の交差 | box(box '((0,0),(1,1))',box '((0.5,0.5),(2,2))') |
center(object) | point (座標点) | 要素の中心 | center(box '((0,0),(1,2))') |
diameter(circle) | double precision (倍精度) | 円の半径 | diameter(circle '((0,0),2.0)') |
height(box) | double precision (倍精度) | 矩形の高さ | height(box '((0,0),(1,1))') |
isclosed(path) | boolean (論理値) | 閉じた道? | isclosed(path '((0,0),(1,1),(2,0))') |
isopen(path) | boolean (論理値) | 開いた道? | isopen(path '[(0,0),(1,1),(2,0)]') |
length(object) | double precision (倍精度) | 要素の長さ | length(path '((-1,0),(1,0))') |
pclose(path) | path (道) | 道を閉じる変換 | popen(path '[(0,0),(1,1),(2,0)]') |
npoint(path) | integer (整数) | 点の数 | npoints(path '[(0,0),(1,1),(2,0)]') |
popen(path) | path (道) | 開いた道に変換 | popen(path '((0,0),(1,1),(2,0))') |
radius(circle) | double precision (倍精度) | 円の半径 | radius(circle '((0,0),2.0)') |
width(box) | double precision (倍精度) | 幅 | width(box '((0,0),(1,1))') |
Table 4-20. 幾何型変換関数
関数 | 返り値 | 説明 | 例 |
---|---|---|---|
box(circle) | box (矩形) | 円から矩形 | box(circle '((0,0),2.0)') |
box(point, point) | box (矩形) | 座標点を矩形に変換 | box(point '(0,0)', point '(1,1)') |
box(polygon) | box (矩形) | 多角形を矩形に変換 | box(polygon '((0,0),(1,1),(2,0))') |
circle(box) | circle (円) | 円に変換 | circle(box '((0,0),(1,1))') |
circle(point, double precision) | circle (円) | 座標点を円に変換 | circle(point '(0,0)', 2.0) |
lseg(box) | lseg (線分) | 矩形の対角線を線分に変換 | lseg(box '((-1,0),(1,0))') |
lseg(point, point) | lseg (線分) | 座標点を線分に変換 | lseg(point '(-1,0)', point '(1,0)') |
path(polygon) | point (座標点) | 多角形を道に変換 | path(polygon '((0,0),(1,1),(2,0))') |
point(circle) | point (座標点) | 円の中心 | point(circle '((0,0),2.0)') |
point(lseg, lseg) | point (座標点) | 線分の交点 | point(lseg '((-1,0),(1,0))', lseg '((-2,-2),(2,2))') |
point(polygon) | point (座標点) | 円の中心 | point(polygon '((0,0),(1,1),(2,0))') |
polygon(box) | polygon (多角形) | 12 角形 | polygon(box '((0,0),(1,1))') |
polygon(circle) | polygon (多角形) | 12 角形 | polygon(circle '((0,0),2.0)') |
polygon(npts, circle) | polygon (多角形) | npts 多角形 | polygon(12, circle '((0,0),2.0)') |
polygon(path) | polygon (多角形) | 道から多角形に変換 | polygon(path '((0,0),(1,1),(2,0))') |