8.7. 幾何データ型

幾何データ型は2次元空間オブジェクトを表現します。 表8-16は、PostgreSQLで使用可能な幾何データ型を列挙したものです。 もっとも基本となる型はpointで、すべての他の型の基礎を形成します。

表 8-16. 幾何データ型

型名格納サイズ表現説明
point16バイト平面における座標点(x,y)
line32バイト無限の直線 (完全には実装されていません)((x1,y1),(x2,y2))
lseg32バイト有限の線分((x1,y1),(x2,y2))
box32バイト矩形((x1,y1),(x2,y2))
path16+16nバイト閉経路(多角形に類似)((x1,y1),...)
path16+16nバイト開経路[(x1,y1),...]
polygon40+16nバイト多角形(閉経路に類似)((x1,y1),...)
circle24バイト<(x,y),r>(中心と半径)

拡大縮小、変形、回転、交点の算出といった様々な幾何学的操作を行う関数と演算子の集合が豊富に揃っています。 このことについては項9.9に説明があります。

8.7.1. 座標点

座標点は幾何データ型の基礎となる2次元構成要素です。 point型の値は次の構文で指定されます。

( x , y )
  x , y

ここでxyは、それぞれの座標を浮動小数点数数値で表したものです。

8.7.2. 線分

線分(lseg)は座標点の組合せで表現されます。 lseg型の値は次の構文で指定されます。

( ( x1 , y1 ) , ( x2 , y2 ) )
  ( x1 , y1 ) , ( x2 , y2 )  
    x1 , y1   ,   x2 , y2

ここで、(x1,y1)(x2,y2)は線分の終端点です。

8.7.3. 矩形

矩形は、矩形の対角線の両端の座標点の組み合わせで表されます。 box型の値は以下の構文で指定されます。

( ( x1 , y1 ) , ( x2 , y2 ) )
  ( x1 , y1 ) , ( x2 , y2 )  
    x1 , y1   ,   x2 , y2

ここで(x1,y1)(x2,y2)は矩形の対角線の両端です。

矩形は最初に示した構文で出力されます。 頂点は、右上の頂点を最初に、左下の頂点をその後に格納するよう入力時に並べられます。 矩形の他の頂点を入力しても構いませんが入力の左下と右上の頂点から矩形が決定され、そして格納されます。

8.7.4. 経路

経路は接続している座標点の集まりで表現されます。 経路は最初の座標点と最後の座標点が接続されていない開いている状態か、最初の座標点と最後の座標点が接続されている閉じた状態かのいずれかです。 ある経路を強制的に開いた状態や閉じた状態にするpopen(p)pclose(p)関数が提供されていて、またisopen(p)isclosed(p)関数で、式の中でどちらの形式かを検証できます。

path型の値は次の構文で指定されます。

( ( x1 , y1 ) , ... , ( xn , yn ) )
[ ( x1 , y1 ) , ... , ( xn , yn ) ]
  ( x1 , y1 ) , ... , ( xn , yn )  
  ( x1 , y1   , ... ,   xn , yn )  
    x1 , y1   , ... ,   xn , yn    

ここで、各座標点は、経路を構成する線分の終端点です。 大括弧([])は開経路を、括弧(())は閉経路を示します。

経路は最初の構文で出力されます。

8.7.5. 多角形

多角形は座標点の集まりで表現されます。 多角形はたぶん閉経路と同じと考えられるかもしれませんが、異なった方式で格納されると同時にそれぞれ独自に支援するルーチン一式を持っています。

polygon型の値は次の構文で指定されます。

( ( x1 , y1 ) , ... , ( xn , yn ) )
  ( x1 , y1 ) , ... , ( xn , yn )  
  ( x1 , y1   , ... ,   xn , yn )  
    x1 , y1   , ... ,   xn , yn    

各座標点は多角形の境界を構成する線分の終端点です。

多角形は最初の構文で出力されます。

8.7.6. 円

円は中心座標点と半径で表現されます。 circle型の値は次の構文で指定されます。

< ( x , y ) , r >
( ( x , y ) , r )
  ( x , y ) , r  
    x , y   , r  

ここで(x,y)は円の中心点、rは円の半径です。

円は最初の構文で出力されます。