C SHARP – FORM APPLİCATİON DATASET İLE XML VERİ KAYDETME, DÜZENLEME VE SİLME İŞLEMLER


C ve C++ Programlama    C ve C++ Programlama İle İlgili Paylaşım Kategorisi

Yazar: NickBeLiRSiZZ    0 Yorum    129 Görüntüleme
  • Derecelendirme: 0/5 - 0 oy

Paylaşım Tarihi: 31.01.2016, 13:39:50 #1
NickBeLiRSiZZ Old Mod.
Onaylı Uye
Status: Çevrimdışı Yorumları:292 Konuları:48 Kayıt Tarihi:12.01.2016 Rep Puanı: 22

C Sharp ile DataSet kullanarak formda oluşturduğumuz ilgili değerleri XML’e yazıyor, daha sonra düzenleme ve silme işlemlerini yapabiliyoruz.İş Detay adında verilerimiz mevcut bunlar İş sıra No, İş Detay 1 ve İş Detay 2.Bunları ilk önce kullanıcıdan textbox’lar aracılığı ile alıp datagridview’e kaydediyoruz.Daha sonrasında ise datagridview içindeki verileri dataset ile XML dosyasına aktarabiliyoruz.Eğer programı daha önceden kullanıp veriler kaydetmişsek “Bilgileri XML dosyasından al” butonunu kullanarak verilerimizi XML’den datagridView’e çekiyoruz.Programı ilk açtığımızdan itibaren hiçbir veriyi kaydetmemişsek XML’den verileri yüklerken karşımıza messagebox ile bir hata mesajı çıkıyor.Verilerimizi XML’e kaydederek verilerimizi daha sonraki kullanımlar için saklamış oluyoruz.Eğer XML veya başka bir kaydetme yapmazsak veriler program çalıştığı süre boyunca verileri RAM belleğe kaydediyor ve program kapandığı andan veriler siliniyor.Kullandığımız dataset yöntemi ile verilerimizi sadece XML’e değil istersek veritabanına kolayca aktarabiliyoruz.

Resim http://i1.wp.com/www.programlamadersleri.com/wp-content/uploads/2015/04/CsharpFormXMLKullanimi.jpg?w=583


Kod:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml;              //XML işlemerini yapabilmek için System.XML'i projemize dahil ediyoruz.
 
//http://memoryhackers.com/
 
namespace FormXmlKullanimi
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
 
        private void button1_Click(object sender, EventArgs e)
        {        }
 
        private void buttonEkle_Click(object sender, EventArgs e)
        {//http://memoryhackers.com/
            //Ekle butonuna bastığımızda yapılacaklar.
 
            int n = dataGridView1.Rows.Add();
            // n adında integer bir değişken oluşturuyoruz bunu datagridview'e satır eklerken kullanıyoruz.
            dataGridView1.Rows[n].Cells[0].Value=textBoxSiraNo.Text;
            //Datagridview'in n satırı  0.sütununa textboxsiraNo'nun Text'ini ekliyoruz.
            dataGridView1.Rows[n].Cells[1].Value=textBoxDetay1.Text;
            //Datagridview'in n satırı  1.sütununa textboxDetay1'nin Text'ini ekliyoruz.
            dataGridView1.Rows[n].Cells[2].Value=textBoxDetay2.Text;
            //Datagridview'in n satırı  2.sütununa textboxDetay2'nin Text'ini ekliyoruz.
            //http://memoryhackers.com/
            textBoxSiraNo.Clear();
            //Verileri ekledikten sonra textbox'ı yeni veri girişi için temizliyoruz.
            textBoxDetay1.Clear();
            //Verileri ekledikten sonra textbox'ı yeni veri girişi için temizliyoruz.
            textBoxDetay2.Clear();
            //Verileri ekledikten sonra textbox'ı yeni veri girişi için temizliyoruz.
 
        }
 
        private void buttonXMLKaydet_Click(object sender, EventArgs e)
        {//http://memoryhackers.com/
            //XML Kaydet butonuna tıkladığımızda yapılacaklar.
            DataSet ds = new DataSet("FirmaProjeBilgileri");
            //Verileri dataset'e kaydetmek için "Firma Bilgileri" adından bir dataset oluşturuyoruz.
      
            DataTable dt = new DataTable("Isdetay");
            //Verileri Dataset içinde kaydetmek için "İş Detay"adında datatable oluşturuyoruz.
            //http://memoryhackers.com/
            dt.Columns.Add("SiraNo");//Datatable'ın Sütununa "Sıra No" ekliyoruz.
            dt.Columns.Add("Detay1");//Datatable'ın Sütununa "Detay1" ekliyoruz.
            dt.Columns.Add("Detay2");//Datatable'ın Sütununa "Detay2" ekliyoruz.
            ds.Tables.Add(dt);//Sütunları tablo içine ekliyoruz.
 
 
           foreach (DataGridViewRow r in dataGridView1.Rows)
           {//Oluşacak satır sayısıı bilmediğimizden dolayı foreach döngüsü içinde 
               //DataGridView'in satır sayısı kadar değer döndürüyoruz.
          DataRow row = ds.Tables["IsDetay"].NewRow();
          //Isdetay'da oluşturduğumuz tablo değerlerini eklemek için kullanıyoruz.
          //http://memoryhackers.com/
 
           row["SiraNo"] = r.Cells[0].Value.ToString();
               //Satırdaki SıraNo'nun değerini DetaGridView'den alıyoruz ve geçerli satırın 0.sütünunu alıyoruz.
           row["Detay1"] = r.Cells[1].Value.ToString();
           //Satırdaki Detay1 değerini DetaGridView'den alıyoruz ve geçerli satırın 1.sütünunu alıyoruz.
           row["Detay2"] = r.Cells[2].Value.ToString();
           //Satırdaki Detay2 değerini DetaGridView'den alıyoruz ve geçerli satırın 2.sütünunu alıyoruz.
 
 
           ds.Tables["IsDetay"].Rows.Add(row);
               //Dataset içindeki Isdetay tablosuna satırları ekliyoruz.
           }//http://memoryhackers.com/
           ds.WriteXml("Veri1.xml");
            //Verileri Dataset ile XML'e yazıyoruz.
 
        }
 
        private void buttonXMLAl_Click(object sender, EventArgs e)
        {//http://memoryhackers.com/
            string DosyaYolu = "Veri1" + ".xml";
            //XML dosyamızın var olup olmadığını kontrol için ilk önce bir değişkene dosya yolunu atıyoruz.
            if (System.IO.File.Exists(DosyaYolu))
            {//Eğer Dosyo yolunda belirtilen değer var ise aşağıdaki işlemler yapılıyor.
                DataSet ds = new DataSet();
                //Az önce oluşturduğumuz dataset private olduğundan burada yeniden oluşturuyoruz.
                ds.ReadXml("Veri1.xml");
                //Dataset'imiz ile daha önceden oluşturduğumuz "Veri.xml" dosyasını okutuyoruz.
 
                foreach (DataRow item in ds.Tables["IsDetay"].Rows)
                {//XML dosyasındaki veri sayısını bilmediğimizden "IsDetay" 
                    //tablosundaki satırlar kadar foreach döngüsüne sokuyoruz.
                    int n = dataGridView1.Rows.Add();
                    //Satır sayısını n değişkenine aktarıyoruz.
                    dataGridView1.Rows[n].Cells[0].Value = item[0].ToString();
                    //DataGridView'in n satırının 0. sütununu datasetten gelen 0.sütun ile eşitliyoruz.
                    dataGridView1.Rows[n].Cells[1].Value = item[1].ToString();
                    //DataGridView'in n satırının 1. sütununu datasetten gelen 1.sütun ile eşitliyoruz.
                    dataGridView1.Rows[n].Cells[2].Value = item[2].ToString();
                    //DataGridView'in n satırının 2. sütununu datasetten gelen 1.sütun ile eşitliyoruz.
 
                }//http://memoryhackers.com/
            }//if bitisi
            else {//Eğer XML dosyası yok ise 
                MessageBox.Show("Veri1.XML Bulunamadı.XML Dosyasını Oluşturun.");
                //MessageBox ile uyarı veriliyor.
            }
 
 
        }
 
        private void dataGridView1_MouseDoubleClick(object sender, MouseEventArgs e)
        {
            }
 
        private void dataGridView1_MouseClick(object sender, MouseEventArgs e)
        {//http://memoryhackers.com/
            //DatagridView'in mauseClick Event'ini kullanarak seçili satıra tıklandığından 
            //ilgili textboxların içeriğinin dolmasını sağlıyoruz.
            textBoxSiraNo.Text = dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
            textBoxDetay1.Text = dataGridView1.SelectedRows[0].Cells[1].Value.ToString();
            textBoxDetay2.Text = dataGridView1.SelectedRows[0].Cells[2].Value.ToString();
         
        }
 
        private void buttonDuzenle_Click(object sender, EventArgs e)
        {//Düzenle butonuna bastığımızda datagridview'den değeri textboxlara çekiyoruz.
         
            dataGridView1.SelectedRows[0].Cells[0].Value = textBoxSiraNo.Text;
            dataGridView1.SelectedRows[0].Cells[1].Value = textBoxDetay1.Text;
            dataGridView1.SelectedRows[0].Cells[2].Value = textBoxDetay2.Text;
        }//http://memoryhackers.com/
 
        private void buttonSil_Click(object sender, EventArgs e)
        {//Sil butonuna tıklandığından DataGridView'de tıklamış olduğumuz satırı siliyoruz.
            dataGridView1.Rows.RemoveAt(dataGridView1.SelectedRows[0].Index);
        }
    }
}



Kaydedilen XML dosyası ise şöyle;

Resim http://i2.wp.com/www.programlamadersleri.com/wp-content/uploads/2015/04/CsharpFormXMLKullanimiXML.jpg?w=418


Kullanıcı İmzası
''İnsan Yükselince Kendini Bişi Zanneder''

-Adolf Hitler.


                    

[img=0x450]https://media.giphy.com/media/MrYqi6NBoMGbe/giphy.gif[/img]










Aradığınızı Bulamadınız Mı ?

Konuyu Okuyanlar:
1 Ziyaretçi