Bilgi sözlüğü - Data dictionary

Bir bilgi sözlüğüveya meta veri deposu tanımlandığı gibi IBM Bilgi İşlem Sözlüğü, "anlam, diğer verilerle ilişkiler, köken, kullanım ve biçim gibi veriler hakkında merkezi bir bilgi havuzudur".[1] Oracle bunu meta verili bir tablo koleksiyonu olarak tanımlar. Terim, ilgili birkaç yakından ilişkili anlamdan birine sahip olabilir. veritabanları ve Veritabanı Yönetim Sistemleri (DBMS):

  • Bir belge bir veritabanı veya veritabanı koleksiyonunu açıklama
  • Bir integral bileşen bir DBMS yapısını belirlemek için gerekli
  • Bir parça ara yazılım bir DBMS'nin yerel veri sözlüğünü genişleten veya onun yerini alan

Dokümantasyon

Şartlar bilgi sözlüğü ve veri deposu bir katalogdan daha genel bir yazılım yardımcı programını gösterir. Bir katalog DBMS yazılımı ile yakından bağlantılıdır. İçinde depolanan bilgileri kullanıcıya ve DBA'ya sağlar, ancak esas olarak DBMS'nin çeşitli yazılım modülleri tarafından erişilir, örneğin DDL ve DML derleyiciler, sorgu iyileştirici, işlem işlemcisi, rapor oluşturucular ve kısıt uygulayıcı. Öte yandan, bir bilgi sözlüğü depolayan bir veri yapısıdır meta veriler yani bilgilerle ilgili (yapılandırılmış) veriler. Bağımsız bir veri sözlüğü veya veri havuzu için yazılım paketi, DBMS'nin yazılım modülleri ile etkileşime girebilir, ancak esas olarak bilgi kaynağı yönetimi için bir bilgisayar sisteminin tasarımcıları, kullanıcıları ve yöneticileri tarafından kullanılır. Bu sistemler, sistem donanımı ve yazılım yapılandırması, dokümantasyon, uygulama ve kullanıcılar hakkındaki bilgileri ve ayrıca sistem yönetimiyle ilgili diğer bilgileri tutar.[2]

Bir veri sözlüğü sistemi DBMS Yazılımı tarafından değil, yalnızca tasarımcılar, kullanıcılar ve yöneticiler tarafından kullanılıyorsa, buna pasif veri sözlüğü. Aksi takdirde, buna bir aktif veri sözlüğü veya bilgi sözlüğü. Pasif bir veri sözlüğü güncellendiğinde, manuel olarak ve bir DBMS (veritabanı) yapısındaki herhangi bir değişiklikten bağımsız olarak yapılır. Etkin bir veri sözlüğü ile önce sözlük güncellenir ve sonuç olarak DBMS'de değişiklikler otomatik olarak gerçekleşir.

Veri tabanı kullanıcılar ve uygulama geliştiriciler, bir veya daha fazla veritabanının organizasyonunu, içeriğini ve kurallarını kataloglayan yetkili bir veri sözlüğü belgesinden yararlanabilir.[3] Bu tipik olarak çeşitli ad ve açıklamaları içerir. tablolar (kayıtlar veya Varlıklar) ve içerikleri (alanlar ) artı ek ayrıntılar, örneğin tip ve her birinin uzunluğu veri öğesi. Bir veri sözlüğünün sağlayabileceği bir diğer önemli bilgi parçası, Tablolar arasındaki ilişkidir. Bu bazen Varlık-İlişki diyagramlarında veya Set tanımlayıcıları kullanılıyorsa, veritabanı Tablolarının hangi Setlere katılacağını belirleyerek bahsedilir.

Aktif bir veri sözlüğünde kısıtlamalar temel verilere yerleştirilebilir. Örneğin, bir veri elemanındaki (alan) sayısal verilerin değerine bir Aralık empoze edilebilir veya bir Tablodaki bir Kayıt, başka bir Kayıt Tipi ile bir dizi ilişkiye katılmak için ZORUNLU hale getirilebilir. Ek olarak, dağıtılmış bir DBMS, aktif veri sözlüğünde açıklanan belirli konum özelliklerine sahip olabilir (örneğin, Tabloların fiziksel olarak bulunduğu yer).

Veri sözlüğü, veritabanında sistem tarafından oluşturulan komut dosyaları tarafından oluşturulan ve desteklenen her arka uç DBMS için özel olarak hazırlanmış kayıt türlerinden (tablolar) oluşur. Oracle, "sys" kullanıcısı için belirli görünümlerin bir listesine sahiptir. Bu, kullanıcıların tam olarak ihtiyaç duyulan bilgileri aramasına olanak tanır. Komut dosyaları, bu veritabanı türünün gerektirdiği belirli ifadeyi kullanan CREATE TABLE, CREATE UNIQUE INDEX, ALTER TABLE (referans bütünlüğü için) vb. İçin SQL İfadeleri içerir.

Böyle bir belgede ayrıntı düzeyine ilişkin evrensel bir standart yoktur.

Ara yazılım

Veritabanı uygulamalarının yapımında, ek bir veri sözlüğü yazılımı katmanı tanıtmak faydalı olabilir, örn. ara yazılım, temeldeki DBMS veri sözlüğü ile iletişim kurar. Böyle bir "yüksek seviyeli" veri sözlüğü, ek özellikler ve asıl amacı gereksinimleri değil DBMS'nin temel işlevlerini desteklemek olan yerel "düşük seviyeli" veri sözlüğünün sınırlamalarının ötesine geçen bir esneklik derecesi sunabilir. tipik bir uygulamanın. Örneğin, yüksek seviyeli bir veri sözlüğü alternatif sağlayabilir varlık-ilişki modelleri ortak bir veritabanını paylaşan farklı uygulamalara uyacak şekilde uyarlanmıştır.[4] Veri sözlüğünün uzantıları da yardımcı olabilir sorgu optimizasyonu karşısında dağıtılmış veritabanları.[5] Ek olarak, DBA işlevleri genellikle aktif bir veri sözlüğüne sıkıca bağlanan yeniden yapılandırma araçları kullanılarak otomatikleştirilir.

Yazılım çerçeveleri Amaçlanan hızlı uygulama geliştirme bazen yüksek seviyeli veri sözlüğü olanakları içerir, bu da oluşturmak için gereken programlama miktarını önemli ölçüde azaltabilir menüler, formlar, raporlar ve veritabanının kendisi de dahil olmak üzere bir veritabanı uygulamasının diğer bileşenleri. Örneğin, PHPLens bir PHP sınıf kitaplığı tabloların, dizinlerin oluşturulmasını otomatikleştirmek ve yabancı anahtar kısıtlamalar taşınabilir çoklu veritabanları için.[6] RADICORE araç setinin bir parçası olan başka bir PHP tabanlı veri sözlüğü, programı otomatik olarak oluşturur nesneler, Kodlar ve menüler ve formlar için SQL kodu veri doğrulama ve karmaşık katılır.[7] İçin ASP.NET çevre Temel Bir veri sözlüğü, otomatik veritabanı oluşturma, veri doğrulama, performans geliştirme (Önbelleğe almak ve endeks kullanımı), uygulama güvenliği ve genişletilmiş veri tipleri.[8] Görsel DataFlex özellikleri[9] DataDictionaries'i kullanıcı arabirimi ile temeldeki veritabanı arasında orta katman oluşturmak için sınıf dosyaları olarak kullanma yeteneği sağlar. Amaç, veri bütünlüğünü korumak için standartlaştırılmış kurallar oluşturmak ve bir veya daha fazla ilgili uygulamada iş kurallarını uygulamaktır.

Bazı endüstriler, sistemler arasında birlikte çalışabilirliği sağlamak için teknik standartlar olarak genelleştirilmiş veri sözlüklerini kullanır. Örneğin, emlak endüstrisi aşağıdaki kurallara uymaktadır: RESO'nun Veri Sözlüğü hangisine Ulusal Emlakçılar Derneği yetki[10] onun MLS'ler politika el kitabına uymak.[11] MLS'lerin yerel veritabanları için bu ara eşleme katmanı, MLS kuruluşlarına API hizmetleri sağlayan yazılım şirketleri tarafından desteklenmektedir.

Platforma özel örnekler

Geliştiriciler bir veri açıklaması belirtimi (DDS) bir bağlamda, verileri işleyen uygulama programının dışındaki dosya açıklamalarındaki veri özniteliklerini tanımlamak IBM System i.[12] sys.ts $ Oracle'daki tablo, veritabanındaki her tablo hakkındaki bilgileri depolar. Veri sözlüğünün bir parçasıdır. Oracle Veritabanı yaratıldı.[13]

Tipik özellikler

Sütunlar veya alanlar için bir veri sözlüğünde bulunan tipik öğelerin kapsamlı olmayan bir listesini burada bulabilirsiniz:

  • Varlık veya form adı veya kimlikleri (Varlık Kimliği veya Form Kimliği). Bu alanın ait olduğu grup.
  • Alan adı, örneğin RDBMS alan adı
  • Görüntülenen alan başlığı. Boşsa varsayılan alan adı olabilir.
  • Alan tip (dize, tam sayı, tarih vb.)
  • Minimum ve maksimum değerler, görüntü genişliği veya ondalık basamak sayısı gibi boyutlar.
  • Alan görüntüleme sırası veya sekme sırası
  • Ekrandaki koordinatlar (konumsal veya ızgara tabanlı bir kullanıcı arayüzü ise)
  • Varsayılan değer
  • Açılır liste, birleşik giriş kutusu, onay kutuları, aralık vb. Gibi bilgi istemi türü.
  • Gereklidir (Boolean) - "true" ise değer boş, boş veya yalnızca beyaz boşluk olamaz
  • Salt okunur (Boole)
  • Yabancı anahtar ise referans tablo adı. Doğrulama veya seçim listeleri için kullanılabilir.
  • Çeşitli olay işleyicileri veya. Örnek: "tıklama üzerine", "on-doğrulama" vb. Bkz. olay odaklı programlama.
  • Biçim kodu, örneğin Düzenli ifade veya COBOL tarzı "PIC" ifadeleri
  • Açıklama veya özet
  • Veritabanı dizini özellikler veya şartname

Ayrıca bakınız

Referanslar

  1. ^ ACM, IBM Bilgi İşlem Sözlüğü, 10. baskı, 1993
  2. ^ Ramez Elmasri, Shamkant B. Navathe: Veritabanı Sistemlerinin Temelleri, 3 üncü. ed. mezhep. 17.5, p. 582
  3. ^ TechTarget, Site araması, Veri sözlüğü nedir?
  4. ^ ABD Patenti 4774661, Aktif veri sözlüğü ile veritabanı yönetim sistemi, 19 Kasım 1985, AT&T
  5. ^ ABD Patenti 4769772, Dağıtılmış veritabanları için materyalizasyon erişim planlaması için hem global hem de paralel yerel optimizasyonları kullanan otomatik sorgu optimizasyon yöntemi, 28 Şubat 1985, Honeywell Bull
  6. ^ PHPLens, PHP için ADOdb Veri Sözlüğü Kitaplığı Arşivlendi 7 Kasım 2007 Wayback Makinesi
  7. ^ RADICORE, Veri Sözlüğü nedir?
  8. ^ Base One International Corp., Temel Bir Veri Sözlüğü
  9. ^ GÖRSEL DATAFLEX,özellikleri
  10. ^ "Gayrimenkul İşlem Standartları (RETS) Web API". www.nar.realtor. Alındı 11 Ekim 2020.
  11. ^ "Çoklu Listeleme Politikası El Kitabı". www.nar.realtor. Alındı 11 Ekim 2020.
  12. ^ "IBM System i V5R3 için DDS belgeleri".
  13. ^ "Oracle Concepts - Veri Sözlüğü". www.dba-oracle.com. Alındı 13 Şubat 2017.

Dış bağlantılar