21 Nisan 2009 Salı

Görsel Egitim Videolari

Farkli konularda bir cok webcast in bulundugu bir egitim sitesi. Kesinlikle ziyaret edilmesini öneririm.

http://dimecasts.net

03 Nisan 2009 Cuma

James Kovacs, her yazilimcinin okumasi gereken kitaplar hakkinda güzel bir liste hazirlamis.

http://www.jameskovacs.com/blog/TheBookshelf.aspx

09 Ocak 2009 Cuma

Explore the Data Access Options in Visual Studio 2008

VS.2008 icerisinde data erisim yöntemlerinin anlatildigi güzel bir makale...

http://www.devx.com/codemag/Article/39751/1954

Microsoft ORM cözümü olan ADO.NET Entity Framework'un örneklerle anlatildigi 4 bölümden olusan güzel bir makale serisi.

http://www.scip.be/index.php?Page=ArticlesNET12

21 Ekim 2008 Salı

.NET -> Web.Config dosyasinda upload dosya büyüklügünü ayarlamak

Asp.Net yada web service uygulamalarinda default olarak belirlenen 4 MB dan daha büyük bir dosya upload edilemek istediginde asagidaki hata olusur.

"There was an exception running the extensions specified in the config file.
--> Maximum request length exceeded."

Bu problemi icin web.config dosyasi icerisine elementleri icerisine, asagidaki kod satirlarini ekleyerek cözebiliriz.

<httpRuntime
executionTimeout="1200"
maxRequestLength="10240"
useFullyQualifiedRedirectUrl="false"
minFreeThreads="8"
minLocalRequestFreeThreads="4"
appRequestQueueLimit="100" />


Burada belirtilen maxRequestLength="10240" degeri ile 10 MB kadar dosyalarin upload edilebilcegini ayarlamis oluyoruz.

14 Ekim 2008 Salı

.NET -> .Net siniflarindan XSD schema dosyasi yaratmak.

XML dosyalarinin dogrulanmasinda XSD dosyalarinin kullanildigindan bir önceki yazida bahsetmistim. Bir assembly icerisindeki bir yada birden fazla sinifdan XSD schema dosyasi yaratmak icin, .NET Framework icerisinde bulunan "xsd.exe" yardimci uygulamasi kullanilabilir.

Nasil kullanildigina dair bir örnek verirsek.

xsd C:\TestApplication.exe /t:Product

Burdaki ilk paremetre assembly nin oldugu path bilgisidir. /t: anahtarindan sonra belirtilen deger de assembly icinde schema dosyasi olusturulmak istenen sinif ismidir.

Bu sekilde Product sinifi icin XSD dosyasi uygulama ile ayni dizinde yaratilmis olur.

Olusturulan bu dosya özellikle deserialize islemleri yapilmadan önce, XML dosyanin iceriginin dogrulanmasinda kullanilir.

XML dosyalarinin gecerliligini Schema dosyasi kullanarak kontrol etmek (Validate an XML Document using Schema)

Bir XML dosyanin icerigini kontrol etmek icin schema dosyalarindan faydalanabiliriz.
XML schema dosyasi, XML dosyasinin iceriginin sahip olmasi gereken kurallari tanimlayan, uzantisi XSD (XML Schema Definition) olan dosyalardir.

XSD icerisnde bahsedilen kurallar sunlardir;

- XML dosyasi icinde var olmasi beklenen element ve attibute'ler, bunlara ait olan data tipleri.
- XML dosyasinin yapisi. Elementler ve bu elementlere ait olan child element'ler.
- Child elementlerin sayisi ve sirasi.
- Element'lerin bir text degere sahip olup olmayacagi.

XSD dosyalar icinde tanimlanan element'ler "simple" ve "complex" type olmak üzere ikiye ayrilir. Sadece karakter data barindan element'ler simple type olarak ifade edilir. Elementler onlara bagli olan alt elementlere (nested elements) sahip ise bu tip elementlerde complex type olarak isimlendirilir.

Asagidaki örnekde ProductCatalog.xml dosyasinin, ProductCatalog.xsd dosyasi kullanilarak nasil validate edilecegini görelim. Bu iki dosyanin icerigi asagidaki gibi olacakdir.

ProductCatalog.xml:


ProductCatalog.xsd:


Asagidaki örnek consol uygulamasinda XML dosyanin gecerliligini XSD kullanarak nasil denetlicegimizi görelim:

using System;
using System.Xml;
using System.Xml.Schema;

public class ValidateXml
{
private static void Main()
{
// XmlValidator sinifimiz icerisinde XMLReader sinifi kullanilarak dogrulama islemi yapilacak.
XmlValidator validator = new XmlValidator();
Console.WriteLine("ProductCatalog.xml dogrulama islemi...\n");

//Xml ve Xsd dosyalari uygulamamizin calistigi dizinde.
bool success = validator.ValidateXml("ProductCatalog.xml", "ProductCatalog.xsd");
if (!success)
Console.WriteLine("XML dosyasi icerigi dogrulanamadi!");
else
Console.WriteLine("XML dosyasi icerigi uygun.");

Console.ReadLine();
}
}

public class XmlValidator
{
private bool failed;

public bool Failed
{
get {return failed;}
}

public bool ValidateXml(string xmlFilename, string schemaFilename)
{
// Schema tipinde dogrulama (validation) yapacagimizi tanimliyoruz.
XmlReaderSettings settings = new XmlReaderSettings();
settings.ValidationType = ValidationType.Schema;

// Schema dosyasi yükleniyor..
XmlSchemaSet schemas = new XmlSchemaSet();
settings.Schemas = schemas;
// ilk parametre de kendimiz bir target namespace girebiliriz validate islemi icin
// null olarak birakildiginda "targetNamespace" degeri schema dosyasindan alinir.
schemas.Add(null, schemaFilename);

// Dogrulama yapilirken hata olustugunda calisacak event handler tanimlaniyor.
settings.ValidationEventHandler += ValidationEventHandler;

//Schema ayarlari ile birlikte xml dosyasi okunmak üzere XMLReader nesnesi olusturuluyor.
XmlReader validator = XmlReader.Create(xmlFilename, settings);

failed = false;
try
{
// XML dosyasi icerisindeki tüm datalar okunuyor.
while (validator.Read())
{}
}
catch (XmlException err)
{
// XML dosyasi icersinde gecersiz bir karakter oldugunda yada acilmis bir tag dogru sekilde kapatilmadiginda hataya düser.
Console.WriteLine(err.Message);
failed = true;
}
finally
{
validator.Close();
}

return !failed;
}

private void ValidationEventHandler(object sender, ValidationEventArgs args)
{
failed = true;
// Dogrulama (Validation) hatasini ekrana yazdir.
Console.WriteLine("XML Dogrulama Hatasi: " + args.Message);
}
}


Uygulamayi calistirdigimizda console ekraninda asagidaki ciktiyi aliriz;

ProductCatalog.xml dogrulama islemi...

XML Dogrulama Hatasi: The element 'product' has invalid child element 'description'. List of possible elements expected: 'productPrice'.
XML Dogrulama Hatasi: The element 'product' has invalid child element 'description'. List of possible elements expected: 'productPrice'.
XML dosyasi icerigi dogrulanamadi!



Bu hatanin olusup dogrulama isleminin gerceklesmemesinin nedeni, ProductCatalog.xsd dosyasi icerisinde "complex type product tanimlamasi" altinda belirlenen elementlerde description isimli bir element in tanimlanmamasi, fakat ProductCatalog.xml dosyasindaki node'lar icerisinde description isimli bu elementin var olmasidir.

ProductCatalog.xsd dosya icerisinden

<xsd:element name="productPrice" type="xsd:decimal"/>

satirini sildigimizde, XML dosyanin iceriginin kullanilan schema dosyasina uygun oldugunu ve dogrulama isleminin hatasiz sekilde tamamlandigini görürüz.

Kaynak: Apress Visual C# 2005 Recipes

13 Ekim 2008 Pazartesi

.NET -> Dosya yolu üzerinde "Path" static sinifi ile islemler

System.IO namespace'i altinda bulunan static "Path" sinifi ile dosya yada dizin bilgisi iceren string ifadeler üzerinde islemler yapabiliriz. Yararli metodlardan bazilari;

- ChangeExtension: Dosyanin var olan uzantisi degistirilir. Eger yeni uzanti belirtilmemisse, var olan uzanti silinir.
- GetDirectoryName: Dosyanin bulundugu dizin ismini döndürür.
- GetFileName: Belirtilen dosyayolundan, dosya ismini geri döndürür.
Console.WriteLine(Path.GetFileName(@"..\System\myFile.txt"));
>> myFile.txt

- GetFileNameWithoutExtension: Dosya ismini uzantisi olmaksizin döndürür.
- GetFullPath: Paremetre olarak verilen string sadece dosya ismi barindiriyorsa, uygulamanin calistigi dizin bilgisi ile dosya yolu olusturur. Örnegin uygulama C:\Test dizininde calisiyor olsun.

Console.WriteLine(Path.GetPathRoot("myfile.txt"));
>> C:\Test\myFile.txt

- GetPathRoot: Dosya yolunun root dizinini döndürür.
Console.WriteLine(Path.GetPathRoot(@"C:\Temp\myfile.txt"));
>> C:\

- HasExtension: Dosya yolu uzanti ile sonlaniyorsa True döndürür.
- Combine: iki string ifadeyi birlestirir.
Console.WriteLine(Path.Combine(@"C:\Temp", "myfile.txt"));
>> C:\Temp\myfile.txt

- GetInvalidFileNameChars: Dosya isimlerinde gecersiz olacak karakterlerin listesini char[] array olarak geri döndürür.
- GetInvalidPathChars: Dosya yolu icin gecersiz olan karakterleri char[] array olarak geri döndürür.
- GetTempPath: Sistemin temp dizinini almak icin kullanilir.
- GetTempFileName: Sistemin temp dizini icerinde 0 Byte büyüklügünde bir dosya yaratir ve bu dosyanin dosya yolunu geri döndürür.

08 Ağustos 2008 Cuma

Advantages and disadvantages of using typed datasets

Advantages of typed datasets:

  • Compile-time type checking— Reduces runtime errors by having members based on the data's actual schema as opposed to untyped datasets, where you call a generic function and can pass an object of any type.

  • Schema-specific members— Typed datasets define properties for getting and setting values where the property name is the same as the underlying column name. They also define properties for determining if the column is null and methods for searching the table via primary key(s).

  • Data binding support in VS.NET— Only useful with Windows Forms applications, but bears mentioning if you plan on doing development based entirely on .NET in addition to the mixed-mode programming that is the focus of this book.

  • Intellisense support— When using untyped datasets, you have to know beforehand the names of the columns and the types that the respective columns work with. With typed datasets, as soon as you enter the name of the type, Intellisense displays its members, thereby saving you development and debugging time.

Disadvantages of typed datasets:

  • Versioning— Typed datasets can actually increase development time in situations where your schema changes, because you'll need to update the typed dataset information manually. This is obviously the same problem we've battled for years with CRecordset classes—having to modify them manually when the underlying schema changes.

  • Tightly coupled— In its current design, typed datasets are difficult to extend and can't be modified (as they're auto-generated each time the project is built). In addition, they force a tight coupling of client to data access code, which might not be best for all situations

Kaynak: InformIT

02 Haziran 2008 Pazartesi

Sql Server 2005 - Timeout problemi

Sql Server 2005 de birden fazla index'i ve data yogunlugu olan bir tablonun tasariminda degisiklik yapmak istedigimde ( var olan bir varchar alanin büyüklügü degistirildiginde), asagidaki time out hatasi ile karsilastim.

- Unable to modify table. Timeout expired. The timeout period elapsed prior to completion of the operation or the server is not responding.

Cözüm olarak table designer transaction timeout süresini yükseltmek gerekli. Bunun icin, Sql Server Management Studio da;

Tools > Options > Designers > Table and Database Designers


"Transaction time-out after" alaninda default olarak gelen 30 saniyelik degeri yükseltirsek problemin üstesinden gelebiliriz.


14 Mayıs 2008 Çarşamba

Sql Server Performans

Sql Server Optimizasyonu ile ilgili güzel bir makale...


http://harriyott.com/2006/01/sql-server-performance-tips.aspx