13 Eylül 2014 Cumartesi

SERVERPROPERTY (Transact-SQL)

Bugün sizlere lokasyon ve yapı olarak çeşitli  SQL Server sistemlerine destek veren DBAlerin en çok kullandığı komutlardan birisi olan SERVERPROPERTY komutu vermek istiyorum Sql Server hakkında bilgi almak için kullanılır.


T-SQL Komutunun syntaxı aşağıdaki gibidir.
SERVERPROPERTY ( propertyname )

SELECT  SERVERPROPERTY('ProductVersion') AS ProductVersion,
SERVERPROPERTY('ProductLevel') AS ProductLevel,
SERVERPROPERTY('Edition') AS Edition,
SERVERPROPERTY('EngineEdition') AS EngineEdition;




Property Dönen Değer
Edition SQL Server Instance hangi edition olduğu hakkında bilgi döndürür. Ayrıca 64 bit veya 32bit olup olmadığıda yazar.
EditionID Versiyona göre bir ID döndürür.
 1804890536 = Enterprise
1872460670 = Enterprise Edition: Core-based Licensing
610778273= Enterprise Evaluation
284895786 = Business Intelligence
-2117995310 = Developer
-1592396055 = Express
-133711905= Express with Advanced Services
-1534726760 = Standard
1293598313 = Web
1674378470 = SQL Database
EngineEdition Buda versiyona göre bir sayı döndürür
1 = Personal or Desktop Engine (SQL Server 2005 ve sonraki versiyonlarda kullanılmaz..)
2 = Standard (Standard, Web, and Business Intelligence ise bu sayıyı döndürür.)
3 = Enterprise ( Evaluation, Developer, ve Enterprise editions.)
4 = Express (Express, Express with Tools and Express with Advanced Services)
5 = SQL Database
ServerName Hem server hemde instance bilgisini döndürür.
InstanceName Kullanıcının bağlı olduğu Instance adını döndürür.
IsClustered Server instance failover cluster için konfigüre edilip edilmediğini döndürür. 1 = Clustered. 0 = Not Clustered.
IsFullTextInstalled FullTextIndex ve semantic indexin kurulu olup olmadığı hakkında bilgi döndürür. 1 = Full-text and semantic indexing components kurulu. 0 = Full-text and semantic indexing components kurulu değil.
ComputerNamePhysicalNetBIOS SQL Serverın üzerinde çalıştığı serverın NetBios ismini döndürür.
Collation Varsayılan collation değerini döndürür. Collation, işletim sisteminden bağımsız olup bir dil veya alfabenin karakter kurallarını tanımlar. Örneğin Türkçe dilinde küçük “i” ile büyük “İ”nin aynı olmaması bu dilin collation yapısıyla ilgilidir

Sürümlere farklılıklar gösteren bu özellik için 2014 versiyonu için olanına buradan ulaşabilirsiniz.

7 Eylül 2014 Pazar

SQL Server 2012 Yenilikler-TRY_CONVERT Fonksiyonu

2012 ile gelen fonskiyonlardan bir taneside TRY_CONVERT fonksiyonudur. Veri tipleri arasındaki değişimler için kullanılır.  Dönüştürülme işlemi başarılı olursa değeri döndürür. Eğer dönüştürme işlemi başarısız olursa NULL değer döndürür.

TRY_CONVERT keywordu Level 110 uyumludur.

SELECT
CASE WHEN TRY_CONVERT(float,'Sedat KARAR') IS NULL
THEN 'Cast Failed'
ELSE 'Cast succeeded'
END AS Result;


SET DATEFORMAT dmy;
SELECT TRY_CONVERT(datetime2,'12/31/2010') AS Result


SET DATEFORMAT mdy;
SELECT TRY_CONVERT(datetime2,'12/31/2010') AS Result;


5 Eylül 2014 Cuma

SQL Server 2012 Yenilikler-IFF ve CHOOSE Mantıksal Fonksiyonları

SQL Server 2012 ile beraber gelen IFF ve CHOOSE fonksiyonları ile yazılarıma devam etmek istiyorum.

IFF Fonksiyonu
IFF ifadesi Oracle PL-SQL'de bulunan DECODE fonksiyonuna benzer ancak onun kadar yetenekli değildir. Boolean bir koşulun sonucuna göre  iki durumdan birini geriye değer döndürür. Koşul sağlanıyorsa birinci değer sağlanmıyorsa ikinci değer geriye döndürülür.

DECLARE @a int=45;
DECLARE @b int=40;
SELECT  IFF (@a>@b,'TRUE','FALSE') AS Result;


CHOOSE Fonksiyonu
Choose Fonksiyonu iki veya daha fazla değerin içinden belirtilen sıradaki değeri döndürür.

SELECT CHOOSE ( 3, 'Manager', 'Director', 'Developer', 'Tester' ) AS Result;


SQL Server 2012 Yenilikler-Format Fonksiyonu

SQL Server 2012 ile gelen fonksiyonlardan biriside format fonksiyonudur.  .NET ortamında geçerli olan bütün string formatlama işlemlerinin SQL Serverda geliştirilmesini sağlar. CAST ve CONVERT fonksiyonlarının yerini almıştır. Parasal işlemler, Sayılar ve özellikler tarih formatlarında hayatımızı çok kolaylaştırmaktadır.

FORMAT  ( value , format [,culture] )

A.Basit Format Örneği

DECLARE @d DATETIME='01/01/2011';
SELECT FORMAT (@d,'d','en-US') AS Result;




B.Özel String biçimlendirmede FORMAT Örneği

DECLARE @d DATETIME = GETDATE();
SELECT FORMAT(@d,'dd/MM/yyyy','en-US') AS Result;




4 Eylül 2014 Perşembe

Concat Fonksiyonu

Bugün sizlere SQL Server 2012 ile gelen bir fonksiyon olan Concat fonksiyonundan bahsetmek istiyorum.
Concat fonksiyonu 2 veya daha fazla değeri tek bir string ifadede birleştirmek için kullanılır. + operatörüne göre bazı avantajları vardır. NULL değerin hiç bir etkisi yoktur ve boş değer olarak ifadeye eklenir. Tür dönüşümüne ihtiyaç duymaz.

--A. Basit Olarak Concat Kullanımı 
SELECT CONCAT('Happy','Birthday',11,'/','25') As Result 



--B. Null Değerde Concat Kullanımı
CREATE TABLE #temp (
emp_name nvarchar(200) NOT  NULL,
emp_middlename nvarchar(200) NULL,
emp_lastname nvarchar(200) NOT NULL);

INSERT INTO #temp VALUES ('Name',NULL,'LastName');

SELECT CONCAT(emp_name,emp_middlename, emp_lastname) AS Result 
FROM #temp

Vaka Analizi-Sql Server Performans Problemi

Bu yazımda sizlere destek verdiğim firmalardan birinde karşıma çıkan SQL Server'da her zaman için karşılaşabileceğiniz ve çözümü çok basit olan problemlerden birini anlatmak istiyorum.

Geçen hafta destek için gittiğim firmanın birinden beni aradılar. Sistemlerinin çok yavaş olduğunu gelip analiz etmem gerektiği söylendi. Öncelikle  firmanın yapısından bahsedecek olursak firma sunucu üzerinde sanallaştırma yapısı olarak HYPER-V kullanıyor. 2 TB lık bir storageları var diskler Raid10 olarak yapılandırılmış. Sanal makinalardan bir taneside SQL Server'ın olduğu makina. SQL Server 2008 R2 standart kurulu durumda. SQL Serverı ERP sistemleri ve Mobile Satış Sistemleri için kullanıyorlar.

Firmanın bana bildirdiği hata son bir haftadır çok yavaş çalıştıklarını özellikle kayıt yaparken çok yavaş kaydettiği sistemlerinin artık kaldırmadığı ve yeni bir server ile storage almayı planladıklarını söylediler.

Sistem kaynaklarına ve bilgisayarların  durumlarını incelediğimde çok olağan üstü bir performans beklemediğimin farkındaydım ancak durma seviyesinde bir yavaşlama yoktu. Yanlız kullandıkları ERP programında kayıt işlerken söyledikleri gibi çok yavaş kayıt yapıyordu.

Ben problemin Mobile Satış sisteminden ERP sistemine veri aktarımından kaynaklandığını düşündüm ancak aksi gibi veri aktarımı esnasında kaydetme problemi yoktu. Aksine bu insert işlemi esnasında sistem süper çalışıyordu.

Yaptığım daha derinden :) incelemelerde problemin SQL Serverda olduğunun tespit ettim. SQL Serverda farklı firmalara ait 20 ila 40 GB arasında farklı firmalarına ait databaseler vardır.  SQL Server'daki problem yeni açmış oldukları firmanın kullanmış olduğu databaseydi. Aklıma Turgay SAHTIYAN hocanın makalesi geldi. Veritabanı Otomatik Büyümeleri Kontrolünüz Altında Olsun (Database Auto Growth)  makalesi tam bu problemi ifade ediyordu. Database boyutu 21 GB olmuş ve Autogrowth özelliği aktif olduğu için 1 MB büyüyordu. Bu özellik aktif olduğu için hata vermiyordu ancak performans olumsuz etkilenmişti.

SQL Serverda bulunan Auto Growth özelliği aktifse bu özellik sayesinde veritabanı dosyaları dolduğunda sistem tarafından oransal veya boyutsal olarak bizim belirlediğimiz şekilde büyüyebilir. Autogrowth işlemi diskte yeni bir alan ayırdığı için kaynak tüketimi fazla olan bir işlemdir. Büyümenin boyutlarına göre bu işlem 1-5 saniye sürebilir.  Büyüme tamamlanana kadar ilgili dosyaya gelen okuma ve yazma istekleri bekletildiği için performans sıkıntısı doğacaktır.

Best practice olarak dosyaların büyümesinin  Auto Growth değilde DBAlerin kontrolü altında yapılması önerilir ancak plansız büyümelere karşı yinede Auto Growth özelliği aktif olmalıdır.  Ayrıntıları Turgay Hocanın makalede okuyabilirsiniz.

Bu konuda bende 20 GB olan MDF dosyasını 30 GB ve 50 GB olan log dosyasını ise 80 GB çıkardım. Sistemi tekrar incelediğimde problem ortadan kalkmıştı. Ancak yinede hazır el atmışken sistemleri yenileme kararıda aldık.

Sql Server DateTime Veri Tipindeki Datayı Türkçe Formatında Göstermek

  SQL'de tarihleri farklı formatlarda göstermek için FORMAT fonksiyonunu kullanabilirsiniz. Türkçe kısa tarih formatı genellikle "...