SQLite - Dizinler

Dizinler, veritabanı arama motorunun veri almayı hızlandırmak için kullanabileceği özel arama tablolarıdır. Basitçe söylemek gerekirse, birindexbir tablodaki verilere bir göstericidir. Veritabanındaki bir dizin, bir kitabın arkasındaki dizine çok benzer.

Örneğin, bir kitabın belirli bir konuyu tartışan tüm sayfalarına başvurmak istiyorsanız, önce tüm konuları alfabetik olarak listeleyen ve ardından bir veya daha fazla belirli sayfa numarasına atıfta bulunan dizine başvurursunuz.

Bir dizin, SELECT sorgularını ve WHERE yan tümcelerini hızlandırmaya yardımcı olur, ancak UPDATE ve INSERT deyimleriyle veri girişini yavaşlatır. Veriler üzerinde hiçbir etkisi olmadan dizinler oluşturulabilir veya çıkarılabilir.

Bir dizin oluşturmak, dizini adlandırmanıza, tabloyu ve hangi sütun veya sütunların dizine ekleneceğini belirlemenize ve dizinin artan veya azalan sırada olup olmadığını belirtmenize olanak tanıyan CREATE INDEX deyimini içerir.

Dizinler, UNIQUE kısıtlamasına benzer şekilde benzersiz olabilir, çünkü endeks, bir dizinin bulunduğu sütunda veya sütun kombinasyonunda yinelenen girişleri engeller.

CREATE INDEX Komutu

Temel sözdizimi aşağıdadır CREATE INDEX.

CREATE INDEX index_name ON table_name;

Tek Sütunlu Dizinler

Tek sütunlu bir dizin, yalnızca bir tablo sütununa göre oluşturulan dizindir. Temel sözdizimi aşağıdaki gibidir -

CREATE INDEX index_name
ON table_name (column_name);

Benzersiz Dizinler

Benzersiz dizinler yalnızca performans için değil, aynı zamanda veri bütünlüğü için de kullanılır. Benzersiz bir dizin, tabloya yinelenen değerlerin eklenmesine izin vermez. Temel sözdizimi aşağıdaki gibidir -

CREATE UNIQUE INDEX index_name
on table_name (column_name);

Bileşik Dizinler

Bileşik dizin, bir tablonun iki veya daha fazla sütunundaki bir dizindir. Temel sözdizimi aşağıdaki gibidir -

CREATE INDEX index_name
on table_name (column1, column2);

İster tek sütunlu bir dizin ister bir bileşik dizin oluşturun, bir sorgunun WHERE yan tümcesinde filtre koşulları olarak çok sık kullanabileceğiniz sütunları dikkate alın.

Yalnızca bir sütun kullanılması durumunda, tek sütunlu bir dizin seçim olmalıdır. WHERE yan tümcesinde filtre olarak sıklıkla kullanılan iki veya daha fazla sütun olması durumunda, bileşik dizin en iyi seçim olacaktır.

Örtük Dizinler

Örtük dizinler, bir nesne oluşturulduğunda veritabanı sunucusu tarafından otomatik olarak oluşturulan dizinlerdir. Dizinler, birincil anahtar kısıtlamaları ve benzersiz kısıtlamalar için otomatik olarak oluşturulur.

Example

Aşağıda, maaş sütunu için ŞİRKET tablosunda bir endeks oluşturacağımız bir örnek verilmiştir -

sqlite> CREATE INDEX salary_index ON COMPANY (salary);

Şimdi, ŞİRKET tablosunda bulunan tüm endeksleri kullanarak listeleyelim. .indices aşağıdaki gibi komut -

sqlite> .indices COMPANY

Bu, aşağıdaki sonucu üretecektir, burada sqlite_autoindex_COMPANY_1 , tablonun kendisi oluşturulduğunda oluşturulan örtük bir indeksdir .

salary_index
sqlite_autoindex_COMPANY_1

Tüm indeksler veritabanını aşağıdaki gibi listeleyebilirsiniz -

sqlite> SELECT * FROM sqlite_master WHERE type = 'index';

DROP INDEX Komutu

SQLite kullanılarak bir dizin bırakılabilir DROPkomut. Bir dizini düşürürken dikkatli olunmalıdır çünkü performans yavaşlayabilir veya geliştirilebilir.

Temel sözdizimi aşağıdaki gibidir -

DROP INDEX index_name;

Önceden oluşturulmuş dizini silmek için aşağıdaki ifadeyi kullanabilirsiniz.

sqlite> DROP INDEX salary_index;

Dizinler Ne Zaman Kullanılmamalıdır?

Dizinler bir veritabanının performansını artırmayı amaçlasa da, kaçınılması gereken zamanlar vardır. Aşağıdaki yönergeler, bir dizinin kullanımının ne zaman yeniden değerlendirilmesi gerektiğini belirtir.

Dizinler - içinde kullanılmamalıdır

  • Küçük masalar.
  • Sık sık, büyük toplu güncelleme veya ekleme işlemleri olan tablolar.
  • Yüksek sayıda NULL değer içeren sütunlar.
  • Sıklıkla değiştirilen sütunlar.