Nasıl yapılır: SQL Server 2005 ve SQL Server 2008, istatistikleri yalnızca bir veritabanı oluşturmak için gerekli olan veritabanı meta verilerinin bir komut dosyası oluşturma

Makale çevirileri Makale çevirileri
Makale numarası: 914288 - Bu makalenin geçerli olduğu ürünleri görün.
Hepsini aç | Hepsini kapa

Bu Sayfada

Giriş

Sorgu en iyi duruma getiricisi Microsoft SQL Server 2005 veya Microsoft SQL Server 2008'in aşağıdaki bilgi türlerinden bir en uygun sorgu planlamasını belirlemek için kullanır:
  • Veritabanı meta verileri
  • Donanım ortamı
  • Veritabanı oturum durumu
Genellikle, sorgu en iyi duruma getiricisi bir <a0>test</a0> sistemindeki davranışı yeniden oluşturmak istiyorsanız, tüm bu aynı tür bilgi benzetimini yapmak gerekir.

Microsoft Müşteri Destek Hizmetleri'ne veritabanı meta verilerinin bir komut dosyası oluşturmak isteyebilir. Microsoft Müşteri Destek Hizmetleri'ne, bu komut veritabanı meta verilerin en iyi duruma getiricisi sorunu araştırmak için kullanır. Bu makalede, istatistikleri komut dosyası oluşturmak için gereken adımları açıklar. Bu makalede, sorgu en iyi duruma getiricisi bilgileri kullanma şeklini de anlatılmaktadır.

Daha fazla bilgi

Komut dosyası oluşturmak için bu adımları izlemeden önce SQL Server 2005 kullanıyorsanız, SQL Server Management Studio'yu sürümü SQL Server 2005 Service Pack 2 veya sonraki bir sürümü olduğundan emin olun. Komut dosyası Sihirbazı, SQL Server 2005'te SQL Server Management Studio'yu önceki sürümlerini kullanıyorsanız, doğru çalışması için tüm gerekli seçenekleri için bu makaledeki adımları içermiyor.

Tüm veritabanını komut dosyası

Clone, istatistikleri yalnızca bir veritabanı oluşturduğunuzda, daha kolay ve daha güvenilir tüm veritabanı yerine, tek tek nesneler için komut dosyası komut dosyası olabilir. Tüm veritabanını komut dosyası aşağıdaki faydaları alırsınız:
  • Sorunu yeniden oluşturmak için gerekli olan bağımlı nesnelerin eksik olan sorunlarını da önlersiniz.
  • Gerekli olan nesneleri seçmek için önemli ölçüde daha az adımlar gerektirir.
Not Bir veritabanı için bir komut dosyası oluşturma ve nesne binlerce veritabanı için meta veriler içerir, komut dosyası işlemini önemli ölçüde CPU kaynaklarını tüketir. Yoğun olmayan saatlerde komut dosyası oluşturma öneririz. Veya, ikinci seçenek, tek tek nesneler için komut dosyası oluşturmak için kullanabilirsiniz.

Sorgunuz tarafından başvuruda bulunulan her bir veritabanını komut dosyası için <a0></a0>, aşağıdaki adımları izleyin:
  1. SQL Server Management Studio'yu açın.
  2. Object Explorerveritabanları ' nı genişletin ve sonra da komut dosyası oluşturmak istediğiniz veritabanını bulun.
  3. Veritabanını farenin sağ düğmesiyle tıklayın, Görevler ' in üzerine gelin ve sonra Kodları oluştur'ı tıklatın.
  4. Komut dosyası Sihirbazı'nda doğru veritabanına'nin seçili olduğunu doğrulayın. Komut dosyası tüm nesneleri seçili veritabanındaki onay kutusunu tıklatıp seçin ve ileri ' yi tıklatın.
  5. Komut dosyası seçenekleri Seç iletişim kutusunda, aşağıdaki tabloda listelenen değere varsayılan değeri aşağıdaki ayarları değiştirin.
    Bu tabloyu kapaBu tabloyu aç
    Komut dosyası seçeneğiDeğer seçmek için
    ANSI doldurmaTrue
    Devam etmek hata komut dizileriTrue
    Komut dosyası bağımlı nesneleri oluşturTrue
    Sistem kısıtlama adları içerir.True
    Komut dosyası harmanlamaTrue
    Komut dosyası veritabanı oluşturmaTrue
    Komut dosyası oturumu açmaTrue
    Komut dosyası nesne düzeyi izinlerTrue
    Komut dosyası istatistikleriKomut dosyası istatistikleri ve çubuk grafikler
    Komut dosyası dizinleriTrue
    Komut dosyası TetikleyicileriTrue
    Not Şema dbo farklı oturumlar tarafından sahip olunan nesne içermeyen Kod oturumlar seçeneğini ve Komut dosyası nesne düzeyi izinler seçeneğini gerekli olmayabilir.
  6. Ileri ' yi tıklatın.
  7. Dosya için komut dosyası</a0> seçeneğini tıklatın ve sonra da bir dosya adı girin.
  8. Son ' u tıklatın.

Komut dosyasını tek tek nesneler

Tam veritabanı komut dosyası yerine belirli bir sorgu tarafından başvurulan yalnızca komut dosyası tek tek nesne olabilir. Tüm veritabanı nesnelerini SCHEMABINDING, WITH yan tümcesi kullanarak oluşturulan sürece, ancak, bağımlılık bilgilerini sys.depends</a0> sistem tablosundaki her zaman doğru olmayabilir. Bu bilgi aşağıdaki sorunlardan biri neden olabilir:
  • Komut dosyası işlemini bir bağımlı nesne komut.
  • Kodlama işlemi yanlış sırada nesneleri komut dosyası. Komut dosyasının başarıyla çalışabilmesi için <a0></a0>, el ile oluşturulan kodu düzenlemeniz gerekir.
Bu nedenle, tek tek nesneler için veritabanı çok sayıda nesne vardır ve komut dosyası yoksa uzun götürecek komut dosyası önerilmez. Komut dosyasını tek tek nesneler kullanmanız gerekiyorsa, şu adımları izleyin:
  1. SQL Server Management Studio'yu veritabanları ' nı genişletin ve sonra da komut dosyası oluşturmak istediğiniz veritabanını bulun.
  2. Veritabanını farenin sağ düğmesiyle tıklayın, Komut dosyası veritabanı olarak öğesinin üzerine gelin, CREATE için için işaretleyin ve Dosya</a1>'ı tıklatın.
  3. Bir dosya adı girin ve sonra da <a2>Kaydet</a2>'i tıklatın.

    Ana veritabanı kapsayıcısı komut dosyası. Bu kapsayıcı, dosya, dosya gruplarını, veritabanı ve özellikleri içerir.
  4. Veritabanını farenin sağ düğmesiyle tıklayın, Görevler ' in üzerine gelin ve sonra Kodları oluştur'ı tıklatın.
  5. Doğru veritabanı'nın seçili olduğundan emin olun ve sonra ileri ' yi tıklatın.
  6. Komut dosyası seçenekleri Seç iletişim kutusunda, aşağıdaki tabloda listelenen değere varsayılan değeri aşağıdaki ayarları değiştirin.
    Bu tabloyu kapaBu tabloyu aç
    Komut dosyası seçeneğiDeğer seçmek için
    ANSI doldurmaTrue
    Devam etmek hata komut dizileriTrue
    Sistem kısıtlama adları içerir.True
    Komut dosyası bağımlı nesneleri oluşturTrue
    Komut dosyası harmanlamaTrue
    Komut dosyası oturumu açmaTrue
    Komut dosyası nesne düzeyi izinlerTrue
    Komut dosyası istatistikleriKomut dosyası istatistikleri ve çubuk grafikler
    <a1>Komut</a1> USE DATABASETrue
    Komut dosyası dizinleriTrue
    Komut dosyası TetikleyicileriTrue
    Not Şema dbo farklı oturumlar tarafından sahip olunan nesne içermeyen Kod oturumlar seçeneğini ve Komut dosyası nesne düzeyi izinler seçeneğini gerekli olmayabilir.
  7. Nesne türleri Seç iletişim kutusunda, sorunlu sorgu başvuran tüm veritabanı nesne türlerini seçin.

    Örneğin, sorgu, yalnızca tablolara başvuran Tablolar seçin. Sorgu bir görünüme başvuruyor, görünümler ve tablolar'ı seçin. Kullanıcı tanımlı bir işlev sorunlu sorgu kullanılıyorsa, işlevler ' i seçin.
  8. Sorgu tarafından başvurulan tüm nesne türlerini seçtikten sonra ileri ' yi tıklatın.
  9. 7. Adımda seçtiğiniz her bir veritabanı nesnesi türü için BIR iletişim kutusu görüntülenir. Her iletişim kutusunda, belirli tabloları, görünümleri, işlevler veya diğer veritabanı nesnelerini seçin ve ileri ' yi tıklatın.
  10. Dosya için komut dosyası</a0> seçeneğini tıklatın ve sonra 3. adımda girilen aynı dosya adını belirtin.
  11. Komut dosyası'nı başlatmak için son ' u tıklatın.
Komut dosyası, komut dosyası tamamlandığında, Microsoft Destek mühendisine gönderin. Microsoft Destek mühendisine, ayrıca aşağıdaki bilgiler isteyebilir:
  • Işlemci ve ne kadar fiziksel bellek varsa sayısı da dahil olmak üzere donanım yapılandırma
  • Sorguyu çalıştırdığınızda etkin SET seçenekleri
Not Zaten bu bilgileri SQLDiag rapor veya bir SQL Profiler izlemesi göndererek sağladığınız. Siz de başka bir yöntemi bu bilgileri sağlamak için kullanmış olabilirsiniz.

Bilgileri nasıl kullanılır

Aşağıdaki tablolarda, nasıl sorgu en iyi duruma getiricisi a query plan seçmek için bu bilgileri kullanır açıklanmasına yardımcı olur.

Meta veriler

Bu tabloyu kapaBu tabloyu aç
KısıtlamalarıSorgu en iyi duruma getiricisi kısıtlamaları contradictions sorguyu temel şemaya arasındaki algılamak için sık kullanılır. Örneğin, sorgu, bir "WHERE col = 5" yan tümcesi ve bir "CHECK (col < 5)" Denetim kısıtlaması varsa, hiçbir satır eşleştirileceğini sorgu en iyi duruma getiricisi bilir.

Sorgu en iyi duruma getiricisi benzer türde bir nullability hakkında kesintiler yapar. Örneğin, "WHERE col IS NULL" yan tümcesi true veya false nullability sütunun bağlı ve bir dış birleşim dış tablodan sütun olup olduğu bilinmektedir. FOREIGN KEY kısıtlamaları varlığını önem ve uygun bir birleşim sırasını belirlemek kullanışlıdır. Sorgu en iyi duruma getiricisi birleştirmeler elemek veya yüklemler basitleştirmek için kısıtlama bilgileri kullanabilirsiniz. Bu değişiklikler, temel tablolar erişmek için gereksinimin kaldırabilirsiniz.
StatisticsYoğunluk ve dizin ve istatistikler anahtarının önüne sütun dağıtımını gösteren bir çubuk grafik, istatistik bilgilerini içerir. Yüklemi yapısına bağlı olarak, sorgu en iyi duruma getiricisi yoğunluğu, histogram veya her ikisini de önem düzeyini bir yüklemi tahmin etmek için kullanabilirsiniz. Güncel istatistikleri doğru önem düzeyi tahminleri için gereklidir. Önem düzeyi tahminleri, işleç, maliyet tahmini, girdi olarak kullanılır. Bu nedenle, en uygun sorgu planları almak için iyi bir önem düzeyi tahminleri olması gerekir.
Tablo boyutu (satır ve sayfa sayısı)Sorgu en iyi duruma getiricisi çubuk ve yoğunluk belirli bir yüklemi true veya false olma olasılığını hesaplamak için kullanır. Son önem düzeyi tahmini olasılığı alt işleciyle döndürülen satırların sayısını çarparak hesaplanır. GÇ maliyet tahmini bir etmen tablosunda veya dizin sayfa sayısıdır. Tablo boyutunu tarama maliyetini hesaplamak için kullanılır ve bir dizin arama sırasında erişilen bir sayfa sayısını tahmin ettiğinizde yararlı olur.
Veritabanı SeçenekleriBirkaç veritabanı seçenekleri, en iyi duruma getirme etkileyebilir. Sorgu en iyi duruma getiricisi oluşturur Yeni bir istatistik veya güncel değil güncelleştirme istatistikleri olup olmadığını AUTO_CREATE_STATISTICS ve AUTO_UPDATE_STATISTICS Seçenekler'i etkiler. Giriş sorguyu, sorgu en iyi duruma getiricisi için el için önce giriş sorgu parametreli PARAMETERIZATION düzeyini etkiler. Parameterization önem düzeyi tahmini etkileyebilir ve eşleşen karşı dizin oluşturulmuş görünümler ve diğer en iyi duruma getirmeleri türleri de engelleyebilirsiniz. DATE_CORRELATION_OPTIMIZATION ayarı sütunlar arasındaki bağıntıları aramak en iyi duruma getiricisi neden olur. Bu ayar, önem ve maliyet tahmini etkiler.

Ortam

Bu tabloyu kapaBu tabloyu aç
Oturum SET seçenekleriEtkiler mi ayarlama ANSI_NULLS "NULL NULL =" ifade doğru olarak değerlendirilir. Önem düzeyi tahmini dış birleştirmeler için geçerli ayarı bağlı olarak değişebilir. Ayrıca, belirsiz ifadeler de değişebilir. Örneğin, "col NULL =" ifade ayarına göre farklı olur. Ancak, "col IS NULL" ifade her zaman aynı şekilde değerlendirir.
Donanım KaynaklarıSıralama ve karma işleçleri maliyeti, göreli SQL Server için kullanılabilir bellek miktarına bağlıdır. Örneğin, sorgu en iyi duruma getiricisi verileri her zaman biriktirilmesine gerekir biliyor verinin boyutunu önbelleği büyükse, diske. Verilerin boyutunu önbelleği çok küçük, ancak, işlem bellekte yapılmış olması olasıdır. SQL Server sunucunun birden fazla işlemci varsa ve parallelism "MAXDOP" bir ipucu veya parallelism en büyük ölçüde yapılandırma seçeneğini kullanarak devre dışı değil farklı en iyi duruma getirmeleri da dikkate alır.
SQL Server stok birimi (SKU) tutmaBazı özellikler, yalnızca belirli sürümleri SQL Server 2005'in veya SQL Server 2008'in üzerine etkinleştirilir. Örneğin, dizin oluşturulmuş görünümler karşı sorgu eşleşen yalnızca SQL Server 2005 Enterprise Edition oluşur. Benzer şekilde, planı kılavuzları karşı eşleşen SQL Server 2000 Standard Edition ve SQL Server 2005 Enterprise Edition için sınırlıdır.

Özellikler

Makale numarası: 914288 - Last Review: 7 Nisan 2009 Salı - Gözden geçirme: 3.0
Bu makaledeki bilginin uygulandığı durum:
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL 2005 Server Enterprise
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
Anahtar Kelimeler: 
kbmt kbexpertiseinter kbexpertiseadvanced kbsql2005engine kbhowto kbinfo KB914288 KbMttr
Machine-translated Article
ÖNEMLİ: Bu makale, bir kişi tarafından çevrilmek yerine, Microsoft makine-çevirisi yazılımı ile çevrilmiştir. Microsoft size hem kişiler tarafından çevrilmiş, hem de makine-çevrisi ile çevrilmiş makaleler sunar. Böylelikle, bilgi bankamızdaki tüm makalelere, kendi dilinizde ulaşmış olursunuz. Bununla birlikte, makine tarafından çevrilmiş makaleler mükemmel değildir. Bir yabancının sizin dilinizde konuşurken yapabileceği hatalar gibi, makale; kelime dağarcığı, söz dizim kuralları veya dil bilgisi açısından yanlışlar içerebilir. Microsoft, içeriğin yanlış çevrimi veya onun müşteri tarafından kullanımından doğan; kusur, hata veya zarardan sorumlu değildir. Microsoft ayrıca makine çevirisi yazılımını sıkça güncellemektedir.
Makalenin İngilizcesi aşağıdaki gibidir:914288

Geri Bildirim Ver

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com