C# Veritabanı İşlemleri

Merhaba arkadaşlar bu yazımda size C# ile veri tabanı işlemlerinden bahsedeceğim. Anlatımlarım da hem Access için gerekli kodları hemde MS SQL için gerekli olan kod parçacıklarını vereceğim. Bazı kod parçacıkları kendim kullandığım şekildedir.  İnternette araştırarak daha farklı şekilde de aynı işlemleri yaptırabilirsiniz.

Bağlantı (Connect) : Veri tabanının özellikleri, dosya yolu vb. gibi bilgileri içerir. Bu bigileri tutmak için Access’de OleDbConnetion, MS SQL’de ise SqlConnetion fonksiyonu kullanılır.

Access : OleDbConnection baglan = new OleDbConnection(“provider=microsoft.jet.oledb.4.0; Data Source=veritabanıAdı.mdb”);

MS SQL : SqlConnection baglan = new SqlConnection(“Data Source=./;Initial Catalog=veritabanıAdı;Integrated Security=true”);

 Kayıt Ekleme (İnsert) : Veri tabanına kolon isimlerine karşılık gelecek şekilde gönderilen parametreleri veri tabanına ekleme işlemini göstereceğim.

Access: 

baglan.Open();
 OleDbCommand cmd = new OleDbCommand("insert into ogrenci (Adı,Soyadı,Tel)values(@adi,@soyadi,@tel)", baglan);
 cmd.Parameters.AddWithValue("@adi", txtAdi.Text);
 cmd.Parameters.AddWithValue("@soyadi", txtSoyadi.Text);
 cmd.Parameters.AddWithValue("@tel", txtTel.Text);
 cmd.ExecuteNonQuery();
 baglan.Close();
 MessageBox.Show("Başarıyla Eklendi", "Bilgi");

MS SQL :

baglan.Open();
SqlCommand cmd = new SqlCommand("insert into musteriler(adı,soyadı,telefon,gsm,adres,mail,bilgi)values(@adi,@soyadi,@tel)", baglan);
cmd.Parameters.AddWithValue("@adi", txtAdi.Text);
cmd.Parameters.AddWithValue("@soyadi", txtSoyadi.Text);
cmd.Parameters.AddWithValue("@tel", txtTel.Text);
cmd.ExecuteNonQuery();
baglan.Close();
MessageBox.Show("Başarıyla Eklendi", "Bilgi");

Bu yazının devamını oku

RSS Takipçim

RSS Takipçim

Bu projemizde istenilen sitenin güncel konularını görüntüleyebilirsiniz.

Hotfile linki silmiş, eğer arşivimde bulursam link eklerim.

Teknik Servis v0.1

Evet yeni projeyle karşınızdayım.Yeni projemin adı Teknik Servis v0.1, bu programı yapmamın asıl amacı iş yerindeki karmaşyı en alt seviyeye indirmekti.

Projeden Görüntü :

Ayarlar ve Hakkında adlı Formlardan Görüntü:

Yedek kısmında ufak bir değişiklik yaptım.Yaptığım değişiklikte istediğiniz yere yedek alabiliyorsunuz.İlerki versiyonlarda ise daha önce yedeklediğiniz veri tabanını seçip onu kullanabileceksiniz.

Diğer Verisiyonlarda Eklenecek Özellikler :

  1. Cihaz Resmi Ekleme
  2. İnternet Üzerinden Yeni Sürüm Güncelleme
  3. İstenilen Veri Tabanının Kullanımı
  4. Kayıt Arama
  5. Kayıtları Excele Aktarma

Ve daha Bir Çok Özellikle Kullanıcı Dostu Program “Teknik Servis” Programı…

Versiyon 0.1 Download Linki : Teknik Servis Programını İndirmek İçin Tıklayınız..

C# Textbox’a Sadece Rakam Girme

İstediğiniz textboxın properties-events bölümünden keypressine çift tıklayın ve açılan kod penceresine alttaki kodu yazınız :

İstediğiniz textboxın properties-events bölümünden keypressine çift tıklayın ve açılan kod penceresine alttaki kodu yazınız :

Kod:
if ((int)e.KeyChar >= 47 && (int)e.KeyChar <=  58)
            {

                e.Handled = false;//Basilan tusu yaz

            }

            else if ((int)e.KeyChar == 8 )
            {

                e.Handled = false;//Basilan tusu yaz

            }

            else
            {

                e.Handled = true;//Basilan tusu yoksay ve yazma

Bu kodu girdiğinizde textboxa rakam dışında bişey yazmayı engeller.

C# Form Boyutunu Kitleme

Formunuzun boyutunun 2 aşamada büyümesini ve küçülmesini engelleyebilirsiniz:

1.Aşama

Kod:
this.FormBorderStyle = FormBorderStyle.FixedSingle;

Bu kodu formunuzun üstüne çift tıklayıp yazın.

2.Aşama

Formunuzun üstüne tıklayın ve ” Properties ” menüsünden ” MaximizeBox ” true konumdadır, bunu false yaptığınızda formunuzun boyutu hiçbir şekilde değiştirilemez.

Umarım İşinize Yarar.

Öğrenci Takip v1.0

İlk database programım olduğundan hataları olabilir.Hatalarımı söylerseniz v1.5 de düzeltirim.

v1.5’da Gelecek Özellikler:

  • Öğrenci Hakkında Kısmı
  • Öğrenci Notları
  • Ve v1.0’daki Hatalar Giderilecek.inş

http://hotfile.com/dl/49918135/6e29af3/renci_Takip_v1.0.rar.html

Programdan SS’ler:

C# ile Faktöriyel Hesabı

C# ile kullanıcının girdiği sayının faktörüyelini bulan Console uygulaması yapalım.

Bu makalemizde klavyeden girilen sayının faktöriyelini hesaplayan programın kodalarını yazacağız.

Kodlarımız;

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace istenilen_sayı_kadar_toplam_alma
{
    class Program
    {
        static void Main(string[] args)
        {
            int toplam = 0, sayi;
            string cvp;
        bas:
            Console.WriteLine("Kaç sayıya kadar faktoriyel istiyosunuz");
            sayi = Convert.ToInt32(Console.ReadLine());
            for (int i = 1; i < sayi + 1; i++)
            {
                Console.WriteLine(i);
                toplam += i;

            }
            Console.WriteLine(sayi + "'ya kadar ki sayıların faktoriyeli=" + toplam);
            Console.WriteLine("Devam Etmek İstermisin Devam E Tuşuna Bitirmek İçin Herhangi Bir tuşa Basın");
            cvp = Console.ReadLine();
            if ((cvp == "e") || (cvp == "E"))
            {
                goto bas;
            }
        }

    }
}

Programımıza yine değişkenlerimizi tanımlayarak başlayalım int türündeki değişkenlerimiz; toplam değişkeni değerleri toplamak için kullanacağız ve bu değeri 0’a eşitliyoruz, 2. değişkenimiz ise sayi değişkenimiz ki bu değişkeni hangi sayıya kadar faktöriyel alacağımızı belirlemek için kullanıcıdan aldığımız değeri atamak için kullanacağız. 3. ve son değişkenimiz ise cvp değişkenimiz bu değişkenimizi ise kullanıcının devam edip etmeyeceğini sorduktan sonra bize dönen değeri atayacağımız değişkenimiz.

Kullanıcıdan hangi sayıya kadar faktöriyel hesabı yapacağımız değeri istiyoruz. Girilen bu değeri sayi değişkenine atadıktan sonra, for döngüsünü 1 den başlatarak sayi değişkenine kadar 1 artarak çalışacak şekilde yazıyoruz. Kullanıcının girdiği değere kadar olan sayıları ekrana yazdırarak toplam değeri üzerine i değerini ekliyoruz.
Hangi sayının faktöriyelini aldıysak o sayıyla birlikte programımızın bulmuş olduğu faktöriyel değerini ekrana yazdırıyoruz. Faktöriyel değeri ekrana yazdırıldıktan sonra kullanıcığının faktöriyel alma işlemine devam edip etmeyeceğini soruyoruz kullanıcı klavyeden “e” yada “E” harfine basarsa goto komutu sayesinde başta oluşturmuş olduğumuz bas etiket noktasına programı odaklayarak tekrar çalışmasını sağlıyoruz. Kullanıcı “e” yada “E” karakterlerinden herhangi birine basmadıysa program otomatik olarak sonlanıyor.

Hepinize çalışmalarınızda başarılar diliyorum.

C# While & Do While Döngüsü

Do While  Döngüsü

While döngüsünden tek fark olarak karşılaştırmanın döngünün sonunda yapılmasıdır. Bu durumda program akışı gereği döngü durum ne olursa olsun koşul sağlanana kadar  execute edilir.

static void Main(string[] args)

{

int sayac = 1;

do

{

Console.WriteLine(sayac + “.satır”);

sayac++; //sayacın değeri burda her defasında artıyo

if (sayac > 5)//sayac 5 ‘den büyük olunca içerdeki kodlar çalışıyo

{

sayac = 1;//burda sayac yeniden 1′e eşitleniyo

Console.WriteLine(“——————-”);

Console.ReadKey();

}

} while (sayac <= 5);//sayac 5 ve 5′den küçük olduğu sürece çalışacak

Console.ReadKey();

while döngüsü koşul deyimini döngü içine girmeden kontrol eder. Eger koşul sağlanmaz ise döngü içine girilmez.

While  Döngüsü

while döngüsü, while parantezindeki koşul deyimi doğru olduğu sürece devam eden bir döngüdür.Tek dikkat etmemiz gereken tanımlanan koşul gerçekleşmişse döngünün execute edilmesidir. Bunun nedeni koşulun döngü başlangıcında bildirilmesidir. Yani

static void Main(string[] args)

{

int sayac=1; //sayac adında integer bir değişken tanımlandı ve sayac 1′e eşitlendi

int toplam=0; //toplam adında integer bir değişken tanımlandı ve toplam değişkeni sıfıra eşitlendi

while (sayac <= 10) //sayac 10 ve 10′dan küçük olduğu sürece içerdeki döngü devamlı çalışssın

{

Console.WriteLine(sayac + “. Rakam”);

toplam = toplam + sayac;

sayac++; //sayaç devamlı artacak(sayac=sayac+1; anlamında)

}

Console.WriteLine(“Sayıların Toplamı: “+toplam);

Console.ReadKey();

}

C# Switch-Case Kullanımı

Switch-case; bir değişkenin aldığı bir çok değere göre farklı komutların çalıştırılması gereken durumlar için kullanılır. Genel yapısı şu şekildedir:

switch(değişken)
{
case durum1: komutlar; break;
case durum2: komutlar; break;
case durum3: komutlar; break;
……
default: komutlar; break;
}

Burada değişkenin değerine göre durumların karşısındaki komutlar çalışır. Eğer değişkenin değeri hiçbir duruma uymuyorsa default kısmındaki komutlar çalışır.

Switch-case için örnek kullanımlara bakacak olursak:

switch (sayi)
    {
        case 1: sonuc = "Pazartesi"; break;
        case 2: sonuc = "Salı"; break;
        case 3: sonuc = "Çarşamba"; break;
        case 4: sonuc = "Perşembe"; break;
        case 5: sonuc = "Cuma"; break;
        case 6: sonuc = "Cumartesi"; break;
         case  7:  sonuc  =   "Pazar";  break;
    }

Ayrıca birkaç durum için aynı komutu çalıştırmak için şu şekilde  kullanabiliriz:

  switch (sayi)
    {
        case 1:
        case 2:
        case 3: sonuc = "Üçüncü Seçim"; break;
        case 4:
        case 5:
        case 6: sonuc = "Altıncı Seçim"; break;
    }

Bunların dışında goto  case deyimi ile bir durumda diğer   durumların komutlarını çalıştırabiliyoruz. Bu deyimin kullanımı ise şu  şekilde:

   switch (sayi)
    {
        case 1: sonuc = "100"; break;
        case 2: sonuc = "200"; break;
        case 3: sonuc = "300"; break;
        case 4: goto case 1; //sonuc değeri 100 olacak

Böylece c sharp ile switch-case kullanımını görmüş olduk.

C# Progress Bar Kullanımı

Nedir bu progressbar ne işe yarar?

Öncelikle progressbar durum çubuğu demektr ve kullanıcıya yapılan işlem hakkında bilgi verir.Kısacası internet explorer’ı açın ve bir site açmaya çalışın eve sayfanın en alt kısmına yani resimdeki yere bakın

progress bar

Evet Burdaki yeşil şey bir progressbar ve bize sitenin ne kadar sürede açılıcağını gösteriyor(aşağı yukarı tabi :) ) Nese bizde bunun gibi bir program yapıcaz. Butona tıkladığımızda listbox’a sayılar eklenmeye başlıcak ve sayı eklemesi bitene kadar progress bar bize işlemin ne durumda olduğunu göstericek.

Öncelikle forumumuza bir adet listbox,bir adet buton ve bir adet progress bar ekleyelim.Programın görüntüsü aşağıdaki gibi olucaktır.

prog2Kodları ;

private void button1_Click(object sender, EventArgs e)
{
progressBar1.Minimum = 1;
progressBar1.Maximum = 10000;
progressBar1.Visible = true;
int k;
for (k = 1; k <= 10000; k++)
{
progressBar1.Value = k;
listBox1.Items.Add(k.ToString());
Application.DoEvents();
}
progressBar1.Visible = false;

}

Açıklaması;

öncelikle progress barı biraz anlatıyım size. Çalışma mantığı her işlemde bir artmasıdır.Minimum ve maximum değeleri belirtmek zorundasınız ve bunlar tabikide int tipinde olmak zorundadır yani 1,23 gibi bir rakam minimum değer olamaz.

ProgressBar’ın minimum değerini ayarlıyoruz. genelikle herkes 1 yapar

progressBar1.Minimum = 1;

Sonra maximum değerini veriyoruz bizimki 1000 yani progress bar 1000 sayısına ulaştığında yeşil cubuk sonda olucak.

progressBar1.Maximum = 10000;

Burada k adında yeni bir değişken yaatıyoruz bunu for döngüsünde kullanıcaz. Daha sonra for dongusu yaratıoruz progress barın değerini 1000 vermiştik hatırlarsanız o yuzden for dongusude 1000′e kadar devam edicek. Döngü her döndüğünde progress bar’ın values’u yani değeri k olucak. yani döngü ilk dondugunde 1 ikincide 2 vs. daha sonra listbox’a bu sayıları ekliyoruz. Application.DoEvents dememizin nedeni ise dongu bittiginde programın çalışmaya devam etmesini sağlamak

int k;
for (k = 1; k <= 10000; k++)
{
progressBar1.Value = k;
listBox1.Items.Add(k.ToString());
Application.DoEvents();
}

Evet Bu kadar 😀