3 Ağustos 2007 Cuma

İçiçe Tablolarla Birleşmeli Dizilerin Farkları

İçiçe tablolar (nested tables) da birleşmeli diziler (associative arrays) de benzer indis yazımı (subscript notation) kullanır, ancak parametre geçirme kolaylığı ve sürdürülebilirlilk açısından farklı özellikleri vardır.

İçiçe tablolar (nested tables), bir veritabanı sütununda tutulabilir ama birleşmeli diziler (associative arrays) tutulamaz. İçiçe tablolar, kalıcı olarak tutulması gereken önemli veri ilişkileri (data relationships) için uygundur.

Birleşmeli diziler, bir yordam (procedure) çağrıldığında veya bir paket (package) başlatıldığında (initialized), topluluğun (collection) bellekte oluşturulabildiği zamanlarda göreceli olarak küçük arama (lookup) tabloları için uygundur. Büyüklüğü önceden bilinmeyen bilgilerin toplanmasında uygundur çünkü birleşmeli dizilerin büyüklükleri önceden sınırlandırılmamıştır, indis değerleri de esnektir; negatif olabilir, sıralı olmayabilir ve uygun olduğunda indis için sayı yerine string değerleri kullanılabilir.

PL/SQL, sayısal anahtar değerleri (numeric key values) kullanan host dizileri ve birleşmeli dizileri kendiliğinden birbirlerine çevirir. Bir veritabanı sunucusundan veya bir veritabanı sunucusuna toplulukları (collections) geçirmenin en etkili yolu, isimsiz (anonymous) PL/SQL blokları kullanmaktır; bu bloklar girdi ve çıktı (input and output) host dizilerini birleşmeli dizilere topluca bağlamakta (bulk-bind) kullanılır.

Hiç yorum yok: