SQL Server Türkçe Karakter Problemi

sql server MSSQL’de eğer databasimizin collation’u Turkish_CI_AS seçilmemişse insert yaparken türkçe karakter problemi yaşamamız mümkün. Eğer veritabanınız GoDaddy gibi yurtdışında bulunan bir hosting firmasında bulunuyorsa collation default olarak Latin1 seçilmiş olabiliyor. Bunu değiştirme yetkiniz yoksa, insert ve update yaparken stringlerimizi unicode olarak göndermemiz gerekli.

Stringleri unicode olarak göndermek için başına büyük N harfi koymamız gerekli.  Bu şekilde gönderilen tüm karakter setleri unicode olarak kaydedilecektir. Bu sayede türkçe karakterlerimiz korunmuş olacaktır.

INSERT INTO dbo.Kitaplar (yazar) VALUES(N’DEITEL’);
Reklamlar

SQL Server Tekrarlanan Satırları Silmek

Sql Server Tekrarlanan satırları silme SQL Server‘da tekrarlanan satırları hızlı bir şekilde silmek için aşağıdaki yöntemi kullanabilirsiniz. Örnek olarak aşağıdaki kod da aynı kişinin puanının birden fazla kez veritabanına kaydedildiğini düşünelim. Yani aynı satırdan birden fazla olduğunu varsayalım, bu aynı satırlardan en eski olanı sistemimizde tutmak istiyorum. Hangisinin eski olduğuna karar vermek için unique olarak tuttuğum id’sinden faydalanacağım. Kısaca id’si küçük olan benim için eklenen en eski kayıttır.

Burada ilk olarak Min() fonksiyonunu kullanarak o kayıttan minimum id’li olan farklı değerlerin id’sini ismine göre group by yaparak çekiyorum. Sonrasında bu idlerin dışında kalan satırları not in ile seçerek siliyorum.

DELETE FROM puanlar WHERE id NOT IN
(SELECT Min(id) FROM puanlar GROUP BY isim)

Eğer en eski yerine en yeni satırı saklamak istersek Min() yerine Max() fonksiyonunu kullanabiliriz.