Geçenlerde clustered primary key contraint'ini nonclustured yapıya dönüştürme ihtiyacım oldu. İhtiyacımın temel sebebi de yanlış oluşturulan clustred bir primary key index'ini nonclustered yapıp farklı bir indexi clustered index'e çevirmek istememdi.
Bu işlemleri online bir sistemde gerçekleştirdiğimden daha titiz olmam gerekiyordu. Bu yüzden aşağıdaki adımları izledim:
- Primary key'ler unique olduğundan key yapısını bozmamak için temporary unique bir index oluşturdum,
- Tablo üstündeki Primary Key'i drop ettim
- Tabloya Primary Key constraint'ini ekledim
- İlk oluşturduğum temporary unique index e artık ihtiyacım kalmadığı için drop ettim.
--temp unique indexi online oluşturma
create unique nonclustered index tmpindex on tablo
(id) with (online=on) on primary
go
--online olarak primary key i drop etme
alter table tablo drop constraint pk_tablo with (online=on)
go
--nonclustered primary key i online olarak oluşturma
alter table tablo add constraint pk_tablo
primary key nonclustered (id) with (online=on) on primary
go
--temp index i drop etme
drop index tablo.tmpindex
go
2 yorum:
Merhaba Mehmet Bey,
Güzel bir konuya değindiğiniz için öncelikle teşekkür etmek istiyorum
Fakat tablo üzerindeki İndexes/Keys penceresinde Primary Key indeximizi "Set As Clustered" özelliğini No yaparak da bu işlemi gerçekleştirebiliyoruz.Tabi buna engel bir durum yoksa.Primary Key'i drop etmek sonradan tekrar oluşturmak biraz riskli olur diye düşünüyorum.
Primary key olan bir clustered index i design modunda bahsettiğiniz şekilde yapamazsınız. Bahsettiğiniz ayarlar disable modda gelir; değişiklik yapmanıza izin verilmez.
Yorum Gönder