Slayt 1 - WordPress.com

advertisement
Elbistan Meslek Yüksek Okulu
2013 – 2014 GÜZ Yarıyılı
25-26 Ara. 2013
Öğr. Gör. Murat KEÇECĠOĞLU
08221 Veri Tabanı II
Indexler
 İndeks, tablolardan veri çekmek için gerekli sorgular
çalıştırılırken gereken süreyi azaltmak amacıyla kullanılır.
 Kayıt sayısının milyonlarla ifade edildiği durumlarda çok
önemlidir.
08221 Veri Tabanı II
ECZA DEPOSU
 İlaçların raflardaki dizilişlerini ele alalım.
 Bir ilaç aradığınızda, ilaçlar bir kurala göre dizilmemişse her
bir ilacı tek tek kontrol etmeniz gerekir.
 İlaçları raflara alfabetik olarak dizerseniz, her bir ilacı tek tek
gözden geçirmek zorunda kalmazsınız.
 Aynı şekilde, ilaç numaralarına göre sıralanmış bir liste
olursa bu ölçütlere göre de aradığınız ilacı kolayca
bulabilirsiniz.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
 Temelde indekslerin üç işlevi vardır:
 Tekil indeksler, veri ilişkilerini ve veri bütünlüğünü sağlayan birincil
anahtar alanlar oluşturmada kullanılır.
 İndeks olan alanın değerine göre bir kaydın kayıtlar arasındaki
sırasını gösterir.
 Sorguların neticelenme sürelerini kısaltır.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Küme ve Küme Olmayan İndeksler
 Küme indekslere clustered index, küme olmayan indekslere de
nonclustered index de denir.
 Clustered indekste tabloda yer alan kayıtlar, fiziksel olarak indeks
tanımlı sütuna göre dizilirler. Bir clustered indeks tarandığında varılan
son nokta verinin kendisidir.
 Bu yüzden, clustered indeksle yapılan aramalar çok hızlı sonuç
verirler.
 Bir tabloda en fazla bir tane clustered indeks tanımlanabilir. Clustered
indeks, özellikle aralık sorguları için yüksek performans sağlar.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Clustered indeksi iki şekilde kullanabilir:
 Clustered indeks araması (seek): Sorgu sonucunda dönecek
kayıtlar üstünde bir kısıtlama varsa (WHERE cümleciği gibi),
clustered indeks araması kullanılır.
 Clustered indeks taraması (scan): Sorgu sonucunda dönecek
kayıtlar üstünde bir kısıtlama yoksa clustered indeks taraması
kullanılır.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
 Tablo üstünde clustered indeksin diğer indekslerden önce
oluşturulmasında fayda vardır.
 Çünkü diğer indekslerin tamamında bu indeksin oluşturulduğu
tekil değer kullanılır.
 Nonclustered indeks, ya yığın (heap) üzerinden veya clustered
indeksin üzerinden verilere erişebilir.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
 Nonclustered indeksler veri erişiminde hızı artırır ancak clustered indeks araması
veya clustered indeks taraması ile birlikte kullanılabilir olduğundan performansları
clustered indekslerden daha düşüktür.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks Oluşturmak
 İndeks oluşturmak için en basit ifade şu şekildedir:
CREATE indeks_tipi INDEX indeks_adı
ON tablo_adı(sütun_adı)
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks Oluşturmak
 İndeks_tipi: Unique clustered veya sadece clustered, nonclustered




şeklinde indeksin tipini belirtir.
Tip belirtilmediğinde nonclustered’dir.
İndeks_adı: İndekse verilen isim.
Tablo_adı: İndeksin tanımlandığı tablo ya da view adı.
Sütun_adı: Tablo ya da view’de indekslenmesi istenen sütun veya
sütunların ismi.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Örnek
 “Person_Bilgi” tablosunda “Sicil_No” sütunu üstünde Clustered
Index tanımlansın.
CREATE CLUSTERED INDEX Ind_Sicil
ON Person_Bilgi (Sicil_No)
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
SQL Server’da sıralı indeks oluşturabilir. Sıralı indeks için ASC
veya DESC deyimleri sütun adlarıyla beraber kullanılır.
Varsayılan sıralama değeri ASC’dir.
Örnek
CREATE INDEX Ind_Brut_Ucret
ON Person_Bilgi (Brut_Ucret DESC)
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Unique İndeks
 Verilerin tekrarlanmaması için kullanılır. Verilerin
tekrarlanmaması için UNIQUE deyimini kullanmak yeterlidir.
 Veri alma ve tekrarı önlemede aynı indeks kullanılabilir.
 UNIQUE indeks, hem clustered hem de nonclustered tipte
olabilir.
 Kısıtlayıcı tanımı yapıldığında Unique indeks otomatik olarak
oluşur.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Unique İndeks
 UNIQUE indeks oluşturulurken indeksin clustered olup
olmayacağı belirtilmelidir.
 Kullanıcı bir seçenek belirtmezse Primary Key Constraint SQL
Server’ca Unique indeks olarak, Unique Constraint’de
nonclustered unique indeks olarak belirlenir.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Örnek
ALTER TABLE Person_Bilgi
ADD CONSTRAINT PK_Sicil PRIMARY KEY(Sicil_No)
CLUSTERED
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Karma (Composite) veya Birleşik İndeks
Birbiriyle ilişkili tablolar arasında bir tablonun iki sütunu birincil anahtar olarak
belirlenebilir. Bu duruma karmaşık veya birleşik indeks denir.
Örnek
ALTER TABLE Personel
ADD CONSTRAINT PK_Personel PRIMARY KEY (TCKimlikNo,Sicil_No) CLUSTERED
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks„te Değişiklik Yapmak
 İndekslerde çeşitli amaçlar doğrultusunda değişiklikler yapılabilir.
 Bir indeks, yeniden derlenebilir (rebuild), yeniden düzenlenebilir (reorganize),
kullanıma kapatılabilir (disable) ve seçenekleri değiştirilebilir (set).
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks„te Değişiklik Yapmak
 Bir indekste değişiklik iki yolla yapılabilir: Management Studio ve DDL ifadelerinden
ALTER INDEX komutu indekste değişiklikler yapılmasını sağlar.
 İndekste değişiklik yapmak için tabloda oluşturulmuş indeks üzerinde fareyle sağ
tıklayınız ve Properties komutunu seçiniz.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks’te Değişiklik Yapmak
 İndekste değişiklik yapmak
için tabloda oluşturulmuş indeks
üzerinde fareyle sağ tıklanır
ve Properties komutunu seçilir.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks’te Değişiklik
Yapmak
Bu pencere üzerinden
indeksin tipini
eğiştirebilir, unique
özelliği verebilir, yeni
bir indeks daha
ekleyebilirsiniz.
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
ALTER INDEX’in kullanımı;
ALTER INDEX indeks_adı veya ALL
ON (tablo_adı.indeks_adı)
(
REBUILD veya
REORGANIZE veya
DISABLE veya
SET (indeks_seçenekleri)
)
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
İndeks Silmek
 Oluşturulan indeks, işlevini yitirirse silinmesi gerekebilir. Bunun
için, DROP INDEX komutu veya indeks özellikleri penceresi
kullanılabilir.
Genel Kullanımı
 DROP INDEX indeks_adı ON tablo_adı
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
“sp_helpindex” Komutu
 Bir tabloda hangi alanlarda ne tür indekslerin tanımlı olduğunu
görmek mümkündür.
 Bu indeksleri görmek için “sp_helpindex” komutu kullanılır.
Genel Kullanımı
 sp_helpindex tablo_adı
08221 Veri Tabanı II
İlişkisel Veritabanında İndeksler
Örnek
 “Person_Bilgi” indeksleri görebilmek için ;
 sp_helpindex Person_Bilgi
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM
 Görünüm (view),
 Sorguları basitleştirmek,
 Erişim izinlerini düzenlemek,
 Farklı sunuculardaki benzer verileri karşılaştırmak
 Sorgu süresini kısaltmak
 Aslında var olmayan, SELECT ifadesi ile tanımlanmış sanal
tablolardır.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM
 Tabloları, olduğundan farklı göstermek için filtreler kullanılır. Bu gibi
işlemler için view kullanılır. View’ler kaydedilmiş sorgulardan oluşur.
 Bir view’in verileri aldığı asıl tabloya temel tablo denir. View, temel
tabloda bulunan sütun ya da sütunları veya satırları kapsayabileceği
gibi birden fazla temel tablo üzerinde tanımlanmış olabilir.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM (VİEW) Kullanım Amaçları
 Kullanıcıların, önemli bir tabloda sadece istenilen sütun veya
satırları görmesini sağlamak,
 Kullanıcıların, uygun birim dönüşümleri yapılmış değerlerini
(mil, km gibi aritmetik işlemler) görmesini sağlamak,
 Tablolarda bulunan verileri başka bir tablo formatında sunmak,
 Karmaşık sorguları basitleştirmek amacıyla kullanılır.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM (VİEW) OLUŞTURMAK
 Tablolarla aynı özelliklere sahiptir. En fazla 1024 sütun
oluşturulabilir.
 View, CREATE VIEW ifadesi kullanılarak oluşturulur.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM (VİEW) OLUŞTURMAK
CREATE VIEW view_adı
AS
SELECT sütun_adları
FROM temel_tablo
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM (VİEW) OLUŞTURMAK
View, iki türlü oluşturulabilir:
 T-SQL kod yazarak
 Object Explorer„da aktif veritabanı görünümünden New View komutunu kullanarak.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM (VİEW) OLUŞTURMAK
Örnek :
Personel veritabanındaki “Person_Bilgi” tablosunda, cinsiyeti “Kadın” olan personeli
ad, soyad ve bölümüyle gösterecek bir view hazırlayacağınızı varsayınız.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
GÖRÜNÜM (VİEW) OLUŞTURMAK
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Aynı işlemi Management
Studio’yu kullanarak da
yapabiliriz.
Veritabanı içindeki Views
klasörü üzerinde fareyle
sağ tuşu tıklarız.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Açılan “Add Table” penceresinde kullanacağınız “Person_Bilgi”
tablosunu Seçeriz.
Add komut
düğmesini tıklarız.
Bu pencereyi
Close düğmesiyle
de
Kapatırız.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Eklenen tablo içersinde kullanılacak alanları işaretleriz.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Alanları seçtiğinizde SELECT ifadesi otomatik olarak yazılacaktır.
Cinsiyeti kadın olan personel view ile gösterileceğinden “Cinsiyet”
alanında bir filtreleme yapılması gerekmektedir.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Oluşturulan view’i vereceğiniz bir isimle (V_CinsiyetKadin)
kaydeder ve son olarak view’i “Open View” komutuyla çalıştırırız.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
View çalıştıktan sonra verilen ölçütlere göre sonucu görebiliriz.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
View’lerde sütun adları belirtilmediği sürece temel tabloda
bulunan sütun adlarıyla aynı olacaktır.
View’le sütun adlarını ihtiyaca göre de değiştirebilirsiniz.
View’de sütunlar için veri tipi belirtilmez çünkü view, temel
tablodan baz alındığı için sütun veri tipleri temel
tablodaki veri tipleriyle aynı olur.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Kısıtlamalar ve İzinler
 View’ler geçici tabloları temel tablo olarak kullanamaz.
 Bunun dışında view’de kullanılan SELECT ifadesi ORDER BY,
COMPUTE veya COMPUT E BY yan cümleciklerini alamaz.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Kısıtlamalar ve İzinler
 View’in tanımlandığı veritabanına erişim izni olmayan
kullanıcılar view’e erişemez.
 Ancak, veritabanında izni olan kullanıcılar miras yöntemi
sayesinde view’e erişebilir.
 Dolayısıyla, view’in bulunduğu veritabanına erişmek demek,
view’e erişmek demektir. Bu durumda view’i oluşturduktan
sonra bir de kullanıcılar için erişim izni tanımlamak gerekir.
 Kullanıcılara izin verilirken temel tabloya asla erişim izni
vermemek ve sadece view’e erişim izni tanımak gerekir.
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
Kısıtlamalar ve İzinler
 Bir view’in hangi tablolara bağlı olduğunu ve bu tabloların
sahiplerinin kim olduğunu sp_depends sistem stored
procedure’ü ile görmek mümkündür.
 Sonuç olarak sahipler Results penceresinde gösterilir
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
View’de Değişiklik Yapmak veya View’i Silmek
Değişiklik Yapmak :
 View üzerinde değişiklik yapmak için ALTER deyimi kullanılır.
ALTER VIEW view_adı
WITH seçenekler
AS
SELECT ifadesi
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
View’de Değişiklik Yapmak veya View’i Silmek
Değişiklik Yapmak :
 View üzerinde değişiklik yapabilmenin
diğer bir yolu da Object Explorer
penceresinde veritabanı altında
oluşturduğunuz view üzerinde
fareyle sağ tıklayarak açılan menüden
Modify komutunu vermektir
08221 Veri Tabanı II
İlişkisel Veritabanında Görünümler
View’de Değişiklik Yapmak veya View’i Silmek
Silmek :
 View’leri silmek için DROP deyimi kullanılır.
DROP view_adı
 Diğer bir yöntem ise, Object Explorer penceresinde veritabanı
altında oluşturduğunuz view üzerinde fareyle sağ tıklayarak
açılan menüden Delete komutunu vermektir.
08221 Veri Tabanı II
IMPORT - EXPORT
08221 Veri Tabanı II
DEVAMI HAFTAYA
Download