• Sonuç bulunamadı

Oracle Spatial 10g Veri Tabanı Üzerine İnceleme ve Deneme Çalışmaları

Ek 3 İstanbul Büyükşehir Belediyesinden Temin Edilen Konuma Bağlı Uygulama Ek 4 Bazı Algoritmaların PL/SQL Karşılıkları

Ek 1 Oracle Spatial 10g Veri Tabanı Üzerine İnceleme ve Deneme Çalışmaları

Oracle Spatial 10g veri tabanı yeteneklerini kullanabilmek için bu bölümde Oracle Spatial kaynaklarında kullanılan örnek gerçekleştirilmiştir. Bu örnekte, pazarda en çok satılan kola markaları, Şekil Ek 1.1’de verilen harita üzerinde konumlarına göre belirlenmiştir.

Şekil Ek 1.1 Kola pazarı

Bu haritada bulunan kola firmalarını Oracle 10g veri tabanında tanımlamak ve çeşitli sorgular yapmak için aşağıdaki işlemler sırayla gerçekleştirilecektir:

• COLA_MARKETS isimli tablonun, uzaya ait verileri saklaması için yaratılması,

• İlgilenilen kola markalarının konum bilgilerine göre tabloya eklenmesi (cola_a, cola_b, cola_c, cola_d),

• USER_SDO_GEOM_METADATA’nın boyut bilgilerini tutmak için güncelleştirilmesi, • Uzaya göre endeksin(COLA_SPATIAL_IDX) yaratılması,

• Uzay sorgularının gerçekleştirilmesi.

Oluşturulacak olan COLA_MARKETS isimli tablodaki her satır, bir kola markası için ilgilenilen bilgiyi tutmaktadır. İlgilenilen bilgi, o coğrafyadaki sakinler tarafından en çok tercih edilen kola markasının olduğu konum veya üretici firmanın potansiyel gördüğü konumlar olabilir. Aşağıda bu tabloyu yaratmak için gerekli SQL verilmiştir:

CREATE TABLE cola_markets ( mkt_id NUMBER PRIMARY KEY,

name VARCHAR2(32),

shape SDO_GEOMETRY);

Daha sonra A kola markası için ilgilenilen konum, tabloya aşağıdaki şekilde eklenir. Bu alan dikdörtgendir. Dikdörtgeni tanımlamak için iki nokta gerekir: sol alt (1,1) ve sağ üst (5,7) noktaları.

INSERT INTO cola_markets VALUES ( 1, ‘cola_a’, SDO_GEOMETRY( 2003, --2 boyutlu poligon NULL, NULL, SDO_ELEM_INFO_ARRAY(1, 1003, 3) -- dikdörtgen 1003 dışı SDO_ORDINATE_ARRAY(1,1, 5,7) ) );

Aynı şekilde B ve C kola markalarının da konumları aşağıdaki şekilde tabloya eklenir. Eklenen bu iki alan birer poligondur. Bir poligon tanımlanırken, başlangıç noktası tekrar tanımlanarak poligon noktaları bitirilir. B kola markası için bu değerler; (5,1, 8,1, 8,6, 5,7 5,1). C kola markası için bu değerler; (3,3, 6,3, 6,5, 4,5 3,3).

INSERT INTO cola_markets VALUES ( 2, ‘cola_b’, SDO_GEOMETRY( 2003, --2 boyutlu poligon NULL, NULL,

SDO_ELEM_INFO_ARRAY(1, 1003, 1) --poligon dışı poligon halka SDO_ORDINATE_ARRAY(5,1, 8,1, 8,6, 5,7 5,1)

) );

INSERT INTO cola_markets VALUES ( 3, ‘cola_c’, SDO_GEOMETRY( 2003, --2 boyutlu poligon NULL, NULL,

SDO_ELEM_INFO_ARRAY(1, 1003, 1)-- poligon dışı poligon halka SDO_ORDINATE_ARRAY(3,3, 6,3, 6,5, 4,5 3,3)

) );

Son olarak da D kola markasının konumu aşağıdaki gibi eklenir. Bu alan, çapı 2 olan bir dairedir. Bir daire üç nokta ile belirlenir.

INSERT INTO cola_markets VALUES ( 4, ‘cola_d’, SDO_GEOMETRY( 2003, --2 boyutlu poligon NULL, NULL,

SDO_ELEM_INFO_ARRAY(1, 1003, 4) -- bir daire SDO_ORDINATE_ARRAY(8,7 10,9, 8,11)

) );

Uzaya ait endeks yaratılmadan önce, metadata bilgileri güncelleştirilmelidir. Her katman (tablo-sütun ilişkisi. Burada COLA_MARKETS ve SHAPE) için bu işlemin sadece bir defa yapılması gerekmektedir.

INSERT INTO user_sdo_geom_metadata (TABLE_NAME, COLUMN_NAME, DIMINFO, SRID) VALUES ( ‘cola_markets’, ‘shape’, SDO_DIM_ARRAY( -- 20 x 20 grid SDO_DIM_ELEMENT (‘X’, 0, 20, 0.005), SDO_DIM_ELEMENT (‘Y’, 0, 20, 0.005) ), NULL, --SRID );

Uzaya ait R_Tree endeksi aşağıdaki şekilde yaratılır; CREATE INDEX cola_spatial_idx

ON cola_markets(shape)

INDEXTYPE IS MDSYS.SPATIAL_INDEX;

Endeks yapısı ile Oracle Spatial’ın sunduğu sorgulama kolaylıkları kullanılabilmektedir. İki kola a ve b firmalarının kesişim alanı aşağıdaki SQL ile elde edilmektedir.

Select SDO_GEOM.SDO_INTERSECTION ( c_a.shape, c_c.shape,0.005) from cola_markets c_a, cola_markets c_c

WHERE c_a.name='cola_a' AND c_c.name='cola_c'; Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

SDO_GEOM.SDO_INTERSECTION(C_A.SHAPE,C_C.SHAPE,0.005)(SDO_GTYPE, SDO_SRID, SDO_PO

--- SDO_GEOMETRY(2003, NULL, NULL, SDO_ELEM_INFO_ARRAY(1, 1003, 1), SDO_ORDINATE_ARR

AY(4, 5, 3, 3, 5, 3, 5, 5, 4, 5))

Belirli bir alanı hesaplama SDO_AREA fonksiyonu ile hesaplanır.

select SDO_GEOM.SDO_AREA(shape, 0.005) FROM cola_markets; Bu komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

SDO_GEOM.SDO_AREA(SHAPE,0.005) --- 24 16.5 5 12.5663706

Verilen iki geometri arasındaki uzaklığı ölçmek için SDO_DISTANCE fonksiyonu kullanılır. select SDO_GEOM.SDO_DISTANCE(c_b.shape, c_d.shape,0.005)

from cola_markets c_b, cola_markets c_d

Bu komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir. SDO_GEOM.SDO_DISTANCE(C_B.SHAPE,C_D.SHAPE,0.005) --- .846049894

Verilen bir geometrinin geçerli olması VALIDATE_GEOMETRY_WITH_CONTEXT fonksiyonu ile gerçekleştirilir.

select c.name, SDO_GEOM.VALIDATE_GEOMETRY_WITH_CONTEXT(c.shape,0.005) from cola_markets c WHERE c.name='cola_c';

Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir. NAME --- SDO_GEOM.VALIDATE_GEOMETRY_WITH_CONTEXT(C.SHAPE,0.005) --- cola_c TRUE

Verilen bir geometriye en yakın 3 komşuluk aşağıdaki sorgu ile elde edilebilir.

select c.mkt_id, c.name from cola_markets c WHERE SDO_NN(c.shape, SDO_GEOMETRY(2001, NULL, SDO_POINT_TYPE(10,7,NULL),

NULL,NULL),'SDO_NUM_RES=3')='TRUE';

Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir. MKT_ID NAME

--- --- 2 cola_b

3 cola_c 4 cola_d

Verilen bir geometriye en yakın 2 komşunun uzaklığı aşağıdaki sorgu ile elde edilir. select

c.mkt_id, c.name, SDO_NN_DISTANCE(1) dist from cola_markets c

WHERE SDO_NN(c.shape, SDO_GEOMETRY(2001, NULL, SDO_POINT_TYPE(10,7,NULL), NULL, NULL),

'sdo_num_res=2', 1) ='TRUE' order by dist; Bu komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

MKT_ID NAME DIST --- --- --- 4 cola_d .828427125 2 cola_b 2.23606798

Verilen bir geometri ile topolojik bir ilişkinin olup olmadığı aşağıdaki sorgu ile elde edilir. SELECT c.mkt_id, c.name

FROM cola_markets c

WHERE SDO_ANYINTERACT(c.shape, SDO_GEOMETRY(2003, NULL, NULL, SDO_ELEM_INFO_ARRAY(1,1003,3), SDO_ORDINATE_ARRAY(4,6, 8,8)) ) = 'TRUE';

Bu komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir. MKT_ID NAME --- --- 2 cola_b 1 cola_a 4 cola_d

Verilen bir geometride CONTAINS topolojik ilişkisi aşağıdaki sorgu ile elde edilir. SELECT c.mkt_id, c.name

FROM cola_markets c

WHERE SDO_CONTAINS(c.shape,

SDO_GEOMETRY(2003, NULL, NULL, SDO_ELEM_INFO_ARRAY(1,1003,3), SDO_ORDINATE_ARRAY(2,2, 4,6)) ) = 'TRUE';

Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir. MKT_ID NAME

--- --- 1 cola_a

Aynı şekilde SDO_COVEREDBY, SDO_COVERS, SDO_EQUAL, SDO_INSIDE, SDO_ON, SDO_OVERLAPBDYDISJOINT, SDO_OVERLAPS, SDO_TOUCH topolojik ilişkileri benzer sorgular ile incelenebilir. 10 birimlik alan içinde olan geometriler aşağıdaki sorgu ile elde edilebilir.

SELECT c.name FROM cola_markets c WHERE SDO_WITHIN_DISTANCE(c.shape, SDO_GEOMETRY(2003, NULL, NULL, SDO_ELEM_INFO_ARRAY(1,1003,3), SDO_ORDINATE_ARRAY(4,6, 8,8)),

'distance=10') = 'TRUE';

İki çizgi aşağıdaki gibi yaratılarak, daha sonra birleştirilebilir.

INSERT INTO cola_markets VALUES(1001, 'line_1', SDO_GEOMETRY(2002, NULL, NULL,

SDO_ELEM_INFO_ARRAY(1,2,1), SDO_ORDINATE_ARRAY(1,1, 5,1)));

INSERT INTO cola_markets VALUES(1002, 'line_2', SDO_GEOMETRY(2002, NULL, NULL,

SDO_ELEM_INFO_ARRAY(1,2,1), SDO_ORDINATE_ARRAY(5,1, 8,1)));

-- Perform aggregate concatenation of all line geometries in layer. SELECT SDO_AGGR_CONCAT_LINES(c.shape) FROM cola_markets c

WHERE c.mkt_id > 1000;

Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

SDO_AGGR_CONCAT_LINES(C.SHAPE)(SDO_GTYPE, SDO_SRID, SDO_POINT(X, Y, Z), SDO_ELEM

--- SDO_GEOMETRY(2002, NULL, NULL, SDO_ELEM_INFO_ARRAY(1, 2, 1), SDO_ORDINATE_ARRAY(

Convex hull alanı aşağıdaki grup(aggregate) fonksiyon ile elde edilebilir. SELECT SDO_AGGR_CONVEXHULL(SDOAGGRTYPE(shape, 0.005)) FROM cola_markets;

Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

SDO_AGGR_CONVEXHULL(SDOAGGRTYPE(SHAPE,0.005))(SDO_GTYPE, SDO_SRID, SDO_POINT(X,

--- SDO_GEOMETRY(2003, NULL, NULL, SDO_ELEM_INFO_ARRAY(1, 1003, 1), SDO_ORDINATE_ARR

AY(8, 1, 10, 7, 10, 11, 8, 11, 6, 11, 1, 7, 1, 1, 8, 1)) MBR, aşağıdaki grup fonksiyon ile elde edilebilir.

SELECT SDO_AGGR_MBR(shape) FROM cola_markets;

Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

SDO_AGGR_MBR(SHAPE)(SDO_GTYPE, SDO_SRID, SDO_POINT(X, Y, Z), SDO_ELEM_INFO, SDO_

--- SDO_GEOMETRY(2003, NULL, NULL, SDO_ELEM_INFO_ARRAY(1, 1003, 3), SDO_ORDINATE_ARR

AY(1, 1, 10, 11))

İki marketin bileşimi aşağıdaki alt programla elde edilebilir. SELECT SDO_AGGR_UNION(

SDOAGGRTYPE(c.shape, 0.005)) FROM cola_markets c

WHERE c.name < 'cola_d';

Kola marketteki topolojik ilişkiler aşağıdaki gibi elde edilebilir. SELECT c.name,

SDO_GEOM.RELATE(c.shape, 'determine', c_b.shape, 0.005) relationship FROM cola_markets c, cola_markets c_b WHERE c_b.name = 'cola_b'; Yukarıdaki komut kullanıldığında, aşağıdaki gibi sorgu cevabı elde edilir.

NAME --- RELATIONSHIP --- cola_a TOUCH cola_b EQUAL cola_c OVERLAPBDYINTERSECT NAME --- RELATIONSHIP --- cola_d DISJOINT

Benzer Belgeler