"Veritabanı Dizini", bir veritabanı tablosundan kayıtların alınmasını hızlandıran özel bir veri yapısı türünü ifade eder. Veritabanı dizinleri, bir veritabanı sorgusu her işlendiğinde her satırı aramak zorunda kalmadan bir veritabanı tablosundaki verileri verimli bir şekilde bulabilmenizi ve bunlara erişebilmenizi sağlar.
Bir veritabanı indeksi, bir kitabın indeksine benzetilebilir. Veritabanlarındaki dizinler, tıpkı bir kitabın dizin sayfasının sizi istediğiniz konuya veya bölüme yönlendirmesi gibi, sizi veritabanında aradığınız kayda yönlendirir.
Bununla birlikte, veritabanı dizinleri hızlı ve verimli veri arama ve erişim için gerekli olmakla birlikte, ek yazma ve bellek alanı kaplarlar.
Endeks Nedir?
Veritabanı dizinleri, iki sütundan oluşan özel arama tablolarıdır. İlk sütun arama anahtarı, ikincisi ise veri işaretçisidir. Anahtarlar, aramak ve veritabanı tablonuzdan almak istediğiniz değerlerdir ve işaretçi veya referans, söz konusu arama anahtarı için veritabanındaki disk bloğu adresini saklar. Anahtar alanlar, tüm sorgularınız için veri alma işlemini hızlandıracak şekilde sıralanır.
Neden Veritabanı İndeksleme Kullanılmalı?
Burada size veritabanı indekslerini basitleştirilmiş bir şekilde göstereceğim. Bir şirkette çalışan sekiz çalışanın bir veritabanı tablonuz olduğunu ve tablonun son girişi için bilgileri aramak istediğinizi varsayalım. Şimdi, önceki girişi bulmak için veritabanının her satırını aramanız gerekir.
Ancak, tabloyu çalışanların ilk adına göre alfabetik olarak sıraladığınızı varsayalım. Bu nedenle, burada indeksleme anahtarları "ad sütununa" dayalıdır. Bu durumda, son girişi ararsanız, “Zack”, tablonun ortasına atlayabilir ve girişimizin sütundan önce mi yoksa sonra mı geleceğine karar verebilirsiniz.
Bildiğiniz gibi orta sıradan sonra gelecek ve yine orta sıradan sonraki sıraları ikiye bölüp benzer bir karşılaştırma yapabilirsiniz. Bu şekilde, son girişi bulmak için her satırı geçmeniz gerekmez.
Şirketin 1.000.000 çalışanı varsa ve son giriş "Zack" olsaydı, adını bulmak için 50.000 satır aramanız gerekirdi. Oysa alfabetik indeksleme ile bunu birkaç adımda yapabilirsiniz. Artık veritabanı indeksleme ile veri arama ve erişiminin ne kadar hızlı olabileceğini hayal edebilirsiniz.
İlişkili: Herhangi Bir Programcının Bilmesi Gereken En Önemli 13 SQL Komutu
Veritabanı İndeksleri İçin Farklı Dosya Organizasyon Yöntemleri
Dizin oluşturma, büyük ölçüde kullanılan dosya düzenleme mekanizmasına bağlıdır. Genellikle, veri depolamak için veritabanı indekslemede kullanılan iki tür dosya düzenleme yöntemi vardır. Aşağıda tartışılmaktadır:
1. Sıralı Dizin Dosyası: Bu, dizin verilerini depolamanın geleneksel yöntemidir. Bu yöntemde, anahtar değerler belirli bir sırada sıralanır. Sıralı bir dizin dosyasındaki veriler iki şekilde saklanabilir.
- Seyrek Dizin: Bu indeksleme türünde her kayıt için bir indeks girişi oluşturulur.
- Yoğun İndeks: Yoğun indekslemede bazı kayıtlar için indeks girişi oluşturulur. Bu yöntemde bir kaydı bulmak için öncelikle aradığınız arama anahtarı değerinden küçük veya ona eşit olan dizin girişlerinden en önemli arama anahtarı değerini bulmanız gerekir.
2. Hash Dosyası organizasyonu: Bu dosya düzenleme yönteminde, bir hash işlevi, bir kaydın depolandığı konumu veya disk bloğunu belirler.
Veritabanı İndeksleme Türleri
Veritabanı İndekslemenin genel olarak üç yöntemi vardır. Onlar:
- Kümelenmiş Dizin Oluşturma
- Kümelenmemiş Dizin Oluşturma
- Çok Seviyeli İndeksleme
1. Kümelenmiş Dizin Oluşturma
Kümelenmiş indekslemede, tek bir dosya ikiden fazla veri kaydını saklayabilir. Sistem, gerçek verileri işaretçiler yerine kümelenmiş dizinlemede tutar. Tüm ilgili verileri aynı yerde depoladığı için kümelenmiş indeksleme ile arama maliyet açısından verimlidir.
Bir kümeleme dizini, kendisini tanımlamak için sıralı veri dosyalarını kullanır. Ayrıca, bu tür indekslemede birden çok veritabanı tablosunu birleştirmek çok yaygındır.
Her anahtar için benzersiz olmayan birincil olmayan sütunlara dayalı bir dizin oluşturmak da mümkündür. Bu gibi durumlarda, kümelenmiş dizinler için benzersiz anahtar değerleri oluşturmak üzere birden çok sütunu birleştirir.
Yani kısaca kümeleme indeksleri, benzer veri türlerinin gruplandırıldığı ve onlar için indekslerin oluşturulduğu yerdir.
Misal: 10 farklı departmanda 1000'den fazla çalışanı olan bir şirket olduğunu varsayalım. Bu durumda şirket, aynı departmanda çalışan çalışanları indekslemek için DBMS'lerinde kümeleme indekslemesi oluşturmalıdır.
Aynı departmanda çalışan çalışanların bulunduğu her küme tek bir küme olarak tanımlanacak ve indekslerdeki veri işaretçileri kümeye bütün bir varlık olarak atıfta bulunacaktır.
İlişkili: SQL Veritabanlarındaki Yabancı Anahtarlar Nelerdir?
2. Kümelenmemiş Dizin Oluşturma
Kümelenmemiş dizin oluşturma, dizin satırlarının sırasının orijinal verilerin fiziksel olarak depolanma şekliyle aynı olmadığı bir dizin oluşturma türünü ifade eder. Bunun yerine, kümelenmemiş bir dizin, veritabanındaki veri deposuna işaret eder.
Misal: Kümelenmemiş dizin oluşturma, sıralı içindekiler sayfasına sahip bir kitaba benzer. Burada, veri işaretçisi veya referansı, alfabetik olarak sıralanmış sıralı içindekiler sayfasıdır ve gerçek veriler, kitabın sayfalarındaki bilgilerdir. İçindekiler sayfası, kitabın sayfalarındaki bilgileri sırayla saklamaz.
3. Çok Seviyeli İndeksleme
Çok seviyeli indeksleme, indeks sayısı çok yüksek olduğunda kullanılır ve birincil indeksi ana bellekte saklayamaz. Bildiğiniz gibi, veritabanı indeksleri arama anahtarlarından ve veri işaretçilerinden oluşur. Veritabanının boyutu arttıkça indeks sayısı da artar.
Ancak hızlı arama işlemini sağlamak için indeks kayıtlarının hafızada tutulması gerekmektedir. Dizin numarası yüksek olduğunda tek düzeyli bir dizin kullanılıyorsa, boyutu ve birden çok erişim nedeniyle bu dizini bellekte depolamak olası değildir.
Çok seviyeli indekslemenin devreye girdiği yer burasıdır. Bu teknik, tek seviyeli dizini birden çok küçük bloğa böler. Yıkıldıktan sonra, dış seviye blok o kadar küçülür ki, ana bellekte kolayca saklanabilir.
İlişkili: Java ile MySQL Veritabanına Nasıl Bağlanılır
SQL Dizin Parçalama Nedir?
İndeks sayfalarının herhangi bir sırası, veri dosyasındaki fiziksel sıra ile eşleşmediğinde, SQL indeks parçalanmasına neden olur. Başlangıçta, tüm SQL dizinleri parçalanmadan bağımsızdır, ancak veritabanını (Veri Ekle/Sil/Değiştir) art arda kullandığınızda, parçalanmaya neden olabilir.
Veritabanı parçalanmasının yanı sıra, veritabanınız, veritabanı bozulması gibi diğer hayati sorunlarla da karşı karşıya kalabilir. Veri kaybına ve zarar görmüş bir web sitesine yol açabilir. Web sitenizle iş yapıyorsanız, bu sizin için ölümcül bir darbe olabilir.
SQL Server için Kurtarma Araç Kutusu, tüm sürümler için bir MS SQL Server'ın bozuk MDF dosyalarını düzeltmeye yardımcı olur.
Sonrakini Oku
- Programlama
- SQL
- Veri analizi
- veri tabanı
Zadhid Powell, yazmaya başlamak için kodlamayı bırakan bir Bilgisayar Mühendisi! Ayrıca Dijital Pazarlamacı, teknoloji meraklısı, SaaS uzmanı, okuyucu ve yazılım trendlerinin keskin takipçisidir. Sık sık onu gitarıyla şehir merkezindeki kulüpleri sallarken veya okyanus tabanı dalışını teftiş ederken bulabilirsiniz.
Haber bültenimize abone ol
Teknik ipuçları, incelemeler, ücretsiz e-kitaplar ve özel fırsatlar için bültenimize katılın!
Bir adım daha…!
Lütfen size az önce gönderdiğimiz e-postadaki e-posta adresinizi onaylayın.