15 Eki 2009 SQL Server 2008 "Saving changes is not permitted" Hatası Kategori: Yazılım Etiketler: SQL Server 30 Yorum SQL Server 2008'i ilk kurup deneyenlerin en çok sorduğu şeylerden birisi tabloyu oluşturduktan sonra tabloda bir değişiklik yapmak istediğimiz de Management Studio'nun buna izin vermeyip yeniden oluşturmamızı istemeseydi. Çözüm çok basit aslında, aşağıdaki adımları uygulayarak bu özelliği kapatabiliyoruz. Tools menüsüne girip Option seçeneğine oradan da Designers'a geçip Table and Database Designers seçeneğini seçiyoruz. Burada işaretli olan Prevent saving changes that require table re-creation checkbox'ın işaretini kaldırırsak bu özellik pasif hale gelecektir.
15 Eki 2009 İnternet mucidinin en büyük hatası Kategori: Yazılım Etiketler: MicrosoftASP.NET 1 Yorum World Wide Web Konsorsiyum'unun direktörü ve M.I.T. profesörü Tim Berners-Lee, bir röportajda kendisine yöneltilen ilginç bir soruya daha ilginç bir cevapla karşılık verdi. İnternetin mucidi olarak tanınan Tim'e "Her şeyi yeniden yapma şansınız olsa neyi farklı yapardınız? Pişmanlıklarınız var mı?" şeklinde bir soru soruldu. Lee ise bugünkü aklı olsa http'den sonraki çift kesme " //" işaretinden bir tanesini çıkartmayı istediğini söyledi. Çift kesme işaretinin o günlerde bir programcılık standardı olduğunu, ancak sonradan bunun gerekli olmadığının anlaşıldığını belirten Lee, eğer çift kesme yerine tek kesme kullanılmış olsaydı insanların ek zahmetten kurtulacağını ve kağıda yapılan baskıda kapladığı yer yüzünden kesilen ağaçların olmayacağını söyledi.Kaynak: http://www.milliyet.com.tr/Dunya/SonDakika.aspx?aType=SonDakika&KategoriID=19&ArticleID=1150214&Date=14.10.2009&b=Internet%20mucidinin%20en%20buyuk%20hatasi
01 Eki 2009 Microsoft'tan Ücretsiz Antivirüs Yazılımı Kategori: Yazılım Etiketler: Microsoft 1 Yorum Microsoft'un ücretsiz antivirüs programı Security Essentials'ı yayınlandı. Eğer ürün hakkında detaylı bilgi almak ve ürünü denemek istiyorsanız aşağıdaki adresi inceleyebilirsiniz. http://www.microsoft.com/Security_essentials
29 Eyl 2009 Microsoft'tan Küçük İşletmelere WebsiteSpark Kategori: Yazılım Etiketler: Microsoft 0 Yorum Microsoft WebsiteSpark programı Türkiye'de de duyuruldu! 10 kişiye kadar çalışanı olan ve ASP.NET, Silverlight, Sharepoint, PHP gibi teknolojilerle web uygulamaları geliştiren şirketlere 3 yıl süre ile ücretsiz yazılımlar sağlıyor.•3 adet Visual Studio 2008 Professional Edition Lisansı•1 adet Expression Studio 3 lisansı (Expression Blend, Sketchflow ve Web!) •Ayrıca 2 adet Expression Web 3 lisansı.•Windows Web Server 2008 R2 4 işlemci lisansı•SQL Server 2008 Web Edition 4 işlemci lisansı•DotNetPanel yönetim paneliDaha da güzeli var! SQL ve Windows Server lisanslarını isterseniz yayın ortamında da kullanabiliyorsunuz. Yani lisansnlar sadece geliştirme ortamı için değil bir hosting sağlayıcıdan alacağınız dedicated sunucunuza bu lisansları kurup uygulamanızı canlı yayına da alabilirsiniz. Tüm bunların yanında Microsoft Partner'ları gibi;•Firma başına iki teknik destek hakkı.•Microsoft’un web şirketleri ekosistemindeki iş ortakları, müşterileri ve tamamlayıcı servisleri ve teknolojilerinden oluşan topluluğa erişim hakkı. •MSDN üzerindeki teknik bilgi ve danışmanlık sunan tartışma gruplarına sınırsız erişim.hizmetlerinden de WebsiteSpark üyesi kuruluşlar faydalanabiliyor.Başvuru için hemen http://www.microsoft.com/web/websitespark/ adresini ziyaret edebilirsiniz.3 yıl sonra ne olacak?Üç yılın sonunda eğer programdan ayrılmak isterseniz 100$'lık bir ödeme yapmanız gerekiyor. Fakat tahmin etmiyorum ki kimse ayrılsın çünkü bu üç senede yayında bile kullanabileceğiniz ücretsiz lisanslar ile çoktan firmanızı kuvvetli bir şekilde ayağa kaldırmış olmanız mümkün. Bu durumda da normal yöntemlerle yıllık 999$ vererek tüm bu lisansların development ortamında kullanılabilecek olanlarını alabilirsiniz ve yayın tarafı için de yine yıllık 199$ ile 1 adet Windows Web Server ve 1 adet SQL Server Web edition edinebilirsiniz. Kişisel kanaatimi sorarsanız bu rakamlar bile bir yazılım şirketinin masrafları arasında en ufak kalemleri oluşturacaktır.Spark programları süper!Microsoft bundan önce de öğrencilere ücretsiz lisans sağlayan DreamSpark ve yazılım üretimi yapan şirketlere ücretsiz lisans sağlayan BizSpark ile güzel bir seriyi başlatmıştı. Bu serinin WebsiteSpark ile devam etmesi gerçekten muhteşem. Artık bir yazılım şirketi kurmak veya bu ekonomik krizde şirketi tekrar ayağa kaldırmak, lisans dertleriyle uğraşmamak çok daha rahat. Kaynakhttp://daron.yondem.com/tr/PermaLink.aspx?guid=7132de37-7259-4459-9051-9edd1dcb12f3
16 Eyl 2009 SQL’ce - LINQ’ce Bölüm 2 Kategori: .NET Framework Etiketler: LINQC# 3.0C# 1 Yorum Merhaba arkadaşlar, bu makalemiz de LINQ mimarisinden bahsedip, SQL içerisinde kullandığımız sorguların LINQ’te nasıl yapıldığını inceleyeceğiz.İlk makalemizde LINQ mimarisine hızlı bir giriş yapmış ve SQL’de yaptığımız temel sorguları(Seçme, sıralama, filtreleme ve gruplama fonksiyonları) LINQ ile yapmıştık. Bu makalemizde de SQL’de yazdığımız diğer sorguları(gruplama, join, subquery) LINQ ile yapacağız. Örnekler için ilk olarak SQL tarafında Ürün ve Kategori isimli iki tablo oluşturalım. Bu tablolar aşağıdaki gibi olacaktır. Sorguları LINQ ile de yazacağımız için yeni bir proje oluşturup Kategori isimli bir class dosyası oluşturalım. Kategori class’ı aşağıdaki gibi olacak. Kategori.cs class Kategori{ public intKategoriID { get; set; } public stringKategoriAdi { get; set; } public static List<Kategori> Kategoriler() { return new List<Kategori>() { new Kategori() { KategoriID = 1, KategoriAdi= "Bilgisayar" }, new Kategori() { KategoriID = 2, KategoriAdi= "Elektronik" }, new Kategori() { KategoriID = 3, KategoriAdi= "Kitap" }, new Kategori() { KategoriID = 4, KategoriAdi= "Giyim" }, new Kategori() { KategoriID = 5, KategoriAdi= "Araba" }, }; }}Projemize yeni bir class dosyası daha ekleyelim. Ürün sınıfı da aşağıdaki gibi olacak. Urun.cs class Urun{ public intUrunID { get; set; } public intKategoriID { get; set; } public stringUrunAdi { get; set; } public doubleFiyat { get; set; } public byteKDV { get; set; } public intStok { get; set; } public boolDurumu { get; set; } public static List<Urun> Urunler() { return new List<Urun>() { new Urun() { KategoriID = 1, UrunAdi = "Laptop", Fiyat = 5, KDV = 8, Stok = 20, Durumu = true}, new Urun() { KategoriID = 1, UrunAdi = "Harici HDD", Fiyat = 4, KDV = 4, Stok = 20, Durumu =true}, new Urun() { KategoriID = 1, UrunAdi = "Memory Stick", Fiyat = 1, KDV = 1, Stok = 30, Durumu = false}, new Urun() { KategoriID = 2, UrunAdi = "LCD TV", Fiyat = 2, KDV = 5, Stok = 250, Durumu = true}, new Urun() { KategoriID = 2, UrunAdi = "DVD Player", Fiyat = 3, KDV = 8, Stok = 20, Durumu = true}, new Urun() { KategoriID = 3, UrunAdi = "Her Yönüyle C#", Fiyat = 5, KDV = 8, Stok = 20, Durumu = true}, new Urun() { KategoriID = 3, UrunAdi = "ASP.NET AJAX", Fiyat = 4, KDV = 4, Stok = 20, Durumu = true}, new Urun() { KategoriID = 3, UrunAdi = "SQL Server 2005", Fiyat = 1, KDV = 1, Stok = 30, Durumu = false}, new Urun() { KategoriID = 3, UrunAdi = "İş Zekası", Fiyat = 2, KDV = 5, Stok = 250, Durumu = true}, new Urun() { KategoriID = 4, UrunAdi = "MS T-Shirt", Fiyat = 3, KDV = 8, Stok = 20, Durumu = true}, new Urun() { KategoriID = 5, UrunAdi = "Alarm", Fiyat = 5, KDV = 8, Stok = 20, Durumu = true}, new Urun() { KategoriID = 5, UrunAdi = "Park Sensörü", Fiyat = 4, KDV = 4, Stok = 20, Durumu = true}, new Urun() { KategoriID = 5, UrunAdi = "Korna", Fiyat = 1, KDV = 1, Stok = 30, Durumu = false}, new Urun() { KategoriID = 5, UrunAdi = "Pasta-Cila", Fiyat = 2, KDV = 5, Stok = 250, Durumu = true}, new Urun() { KategoriID = 5, UrunAdi = "İlkyardım çantası", Fiyat = 3, KDV = 8, Stok = 20, Durumu = true}, }; }}Join İşlemleri SQL’de iki tabloyu birlikte sorgulamak için inner join’i kullanıyoruz. LINQ’te de farklı nesneleri join ile birleştirerek birlikte sorgulayabiliyoruz. Aşağıdaki örnekte Ürün ve Kategori’lerdeki eşleşen tüm kayıtları sorgu sonucunda gelecek. Eğer iki tabloda eşleşmeyen kayıtlar varsa sorgu sonucuna dahil edilmeyecek. SQL LINQ Select * from Urun U inner join Kategori K on U.KategoriID = K.KategoriID from k in Kategori.Kategoriler() join u in Urun.Urunler() on k.KategoriID equals u.KategoriID select new { Urun =u, Kategori = k };Her iki tablo da eşleşen kayıtları listeledik. Fakat eğer her iki tabloda eşleşmeyen alanlar varsa ne olacak? Bu durumu çözmek için SQL’de left outer join’i kullanıyoruz. Bu şu demek oluyor Kategori tablosundaki tüm kayıtlar sorgu sonucuna dahil edilsin Ürün tablosuda dahil edilsin fakat eğer Ürün bilgisi varsa Ürün bilgisi gelsin yoksa null gelsin. LINQ’te birebir left outer join olmasa da aynı sonucu verecek sorguyu aşağıdaki gibi yazabiliyoruz. SQL LINQ Select * from Kategori K left outer join Urun U on U.KategoriID = K.KategoriID from k in Kategori.Kategoriler() joinu in Urun.Urunler() onk.KategoriID equals u.KategoriID into temp from kat in temp.DefaultIfEmpty()select new { Urun =kat, Kategori = k };Yukarıdaki LINQ sorgusunun sonucu aşağıdaki gibi olacaktır. Gruplama İşlemi Belirli bir alan yada alanlara göre verileri gruplamak istediğimiz de SQL’de group by ifadesini kullanararak verileri gruplayabiliyoruz.. LINQ’te de benzer bir durum söz konusu ama syntax olarak bazı farklılıklar var. Aşağıdaki örnek bize her bir kategorideki toplam ürün sayısını verecek. Grupladığımız alan yada alanlara Key özelliği üzerinden erişebiliyoruz. SQL LINQ Select KategoriAdi, count(UrunAdi) from Urun U inner join Kategori K on U.KategoriID = K.KategoriIDgroup by KategoriAdi from k in Kategori.Kategoriler() join u in Urun.Urunler() on k.KategoriID equals u.KategoriID group u by k into gselect new { KategoriAdi = g.Key.KategoriAdi, UrunAdedi = g.Count() };Yukarıdaki LINQ Sorgusunu çalıştırdığımızda aşağıdaki gibi bir görüntü elde edeceğiz. Gruplanmış veri üzerinde filtreleme yapmak istediğimiz de SQL’de having’i kullanıyoruz. LINQ’te ise gruplama işleminden sonra where ile istediğimiz filtrelemeyi yapabiliyoruz. Aşağıdaki örnek Ürün adedi 2’den büyük olan kategorileri ve ürün adetlerini sorgu sonucuna ekleyecek. SQL LINQ Select KategoriAdi, count(UrunAdi) from Urun U right join Kategori K on U.KategoriID = K.KategoriIDgroup by KategoriAdihaving Count(urunAdi) > 2 from k in Kategori.Kategoriler() join u in Urun.Urunler() on k.KategoriID equals u.KategoriID group u by k into gwhere g.Count()>2 select new { KategoriAdi = g.Key.KategoriAdi, UrunAdedi = g.Count() };SubQuery Kullanımı SQL’de bazı durumlar da içiçe sorgular(Subquery) yazmamız gerekebiliyor. Aşağıda ki örnekte Urun nesnesine ait KategoriAdi bilgisini bize veren SubQuery’i yazdık. Aynı sorguyu LINQ ile de yazabiliyoruz. SQL LINQ Select UrunAdi,(Select KategoriAdi From Kategori Where KategoriID = Urun.KategoriID) as KategoriAdiFrom Urun from u in Urun.Urunler()select new {u.UrunAdi, KategoriAdi = (from k in Kategori.Kategoriler() where k.KategoriID == u.KategoriID select k.KategoriAdi).SingleOrDefault()};Yukarıdaki LINQ Sorgusunu çalıştırdığımızda aşağıdaki gibi bir görüntü elde edeceğiz. Bu makalenin de sonuna geldik başka bir makale de görüşmek üzere. LINQ ile kalın ;)Not: Makale de büyük emeği bulunan Cenk Özdemir’e teşekkürlerimi sunarım J Sem GÖKSU www.semgoksu.com | www.yazilimgunlugu.com sem.goksu@yazilimgunlugu.com Kaynaklarmsdn.com