Ana içeriğe atla

Devexpress - GridControl Master Detail Kullanımı

merhaba;

bu makalede devexpress gridcontrol üzerinde master-detail işleminin nasıl yapıldığını açıklamaya çalışacağım.

yukarıdaki resimdede gördüğünüz gibi master-detail yapısı; birden fazla ilişkili tabloyu bir arada göstermeyi amaçlar.bunu yaparken dataset içerisindeki tablolarda ilişki kurmamız gerekmektedir.aşağıdaki örnekte gridcontrol üzerinde master-detail yapısının ne şekilde kurulabileceği belirtilmiştir.



ilk olarak 2 adet tablo oluşturmalıyız.
1. Tablomuz kullanıcı tablosu. Alanları;
Id (int,auto increment,not null)
KullaniciAdi (string,not null)
Soyadi (string,not null)

2. Tablo IletisimBilgileri Alanlari;
Id (int,auto increment,not null)
KullaniciId (int,not null) -->Kullanıcı tablosunun Id alanı ile ilişkili.Child tablo.
Telefon (string,not null)
Mail(string,not null)

//bağlantı için gerekli SqlConnection nesnesi oluşturulur ve bağlantı açılır.
SqlConnection qcon = new SqlConnection("baglantıcumlesi");
qcon.Open();

//SqlDataAdapter nesnesinin yardımıyla her iki tablo da sorgulanarak sonuç dataset'te 2 ayrı tabloya aktarılır.

SqlDataAdapter qadap = new SqlDataAdapter("Select * from Kullanici", qcon);
SqlDataAdapter qIletisimBilgileri = new SqlDataAdapter("Select * from IletisimBilgileri", qcon);

//dataset nesnesi oluşturulur ve DataAdapter nesnelerindeki veriler fill metodu ile DataSet içerisindeki tablolara aktarılır.
DataSet qdataset = new DataSet();
qadap.Fill(qdataset[0]);
qIletisimBilgileri.Fill(qdataset[1]);

//DataSet üzerindeki anahtar ve alt anahtarların tanımı yapılır.
DataColumn AnahtarKolon = qdataset.Tables[0].Columns["Id"];
DataColumn AltAnahtar = qdataset.Tables[1].Columns["Id"];

//DataSet üzerinde yeni bir tablolar arası ilişki tanımlanır ve gridcontrol nesnesinin datasource özelliğine Primary tablo referans gösterilir.
qdataset.Relations.Add("IliskiAdi", AnahtarKolon, AltAnahtar, false);
gridControl1.DataSource = qdataset.Tables[0];
gridControl1.ForceInitialize();
qcon.Close();
ForceInitialize metodu form load olmadan önce grid üzerinde değişiklik yapacaksanız mutlaka kullanmanız gereken bir fonksiyondur.

Daha fazla bilgi için : https://documentation.devexpress.com/#windowsforms/DevExpressXtraGridGridControl_ForceInitializetopic

Hepinize Kolay Gelsin




Yorumlar

Bu blogdaki popüler yayınlar

PAYTR SANAL POS ASP.NET C# Entegrasyonu

merhaba, bu makalede sizlere PAYTR Sanal pos yapısını .NET üzerinde nasıl çalıştıracağımız ile ilgili bilgi aktarmaya çalışacağım. Ücretsiz başlangıç sağlaması ve sabit ödeme almaması sebebiyle düşük bütçeli e-ticaret yapmak isteyen kişilerin tercih ettiği PAYTR Sanal pos entegrasyonu temelde PHP üzerine kurulmuş. Dolayısıyla .net ile e-ticaret yazmaktaysanız bu sizi bir hayli zorluyor zira firma ile birçok görüşme yapmama rağmen sağlıklı bir .net örneklemesi bulamadım. Baktım olacak gibi değil, sonunda oturdum kendi entegrasyonumu kendim yazdım :). aşağıda detaylı olarak bulabilirsiniz. //using satırlarımızı ekleyelim; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Collections.Specialized; using System.Data; using System.Linq; using System.Net; using System.Security.Cryptography; using System.Text; using System.Web; using System.Web.Script.Serialization; using System.Web.UI; using System.Web.UI.WebControls; //aşağıdaki sabit PAYTR Fonksiyon...

ASP.NET Sayfalar arası veri taşıma işlemleri

merhaba; bu yazımda sizlere asp.net üzerinde sayfalar arasında veri taşıma işlemlerinden bahsetmek istiyorum.hepimizin bildiği gibi uygulamarımızda sayfalarımız arası haberleşmeler büyük önem arzetmektedir.bazı sayfalarda bazı işlemlerin yerine getirilebilmesi için diğer sayfalardan gelecek verilere ihtiyaç duyulabilir(GET).ASP.NET üzerinde veri taşıma işlemleri aşağıdaki şekillerde yapılabilir. 1-)QueryString : en yaygın ve basit kullanıma sahip olanıdır.istenilen verileri sayfayı post ettiğiniz zaman yönlendirildiğiniz sayfaya URL üzerinden taşır. Kullanımı : a sayfasından b sayfasına isim taşıyalım. a sayfasında linkinizi şu şekilde değiştirirseniz: Response.Redirect("gidileceksayfa.aspx?isim=can"); Tarayıcınızın URL kısmına baktığınızda: www.siteadi.com/b.aspx?isim=can olarak görürsünüz.a sayfasından veri aktarımı tamamlanmıştır.bundan sonraki adım b sayfasından gelen veriyi almaktan ibarettir.o da şu şekilde yapılır: b sayfasında "isim" adında b...

Devexpress SchedulerControl Kullanımı

Uzun bir aradan sonra merhaba; Sizlere bu makalede Devexpress ürününün en karmaşık kontrollerinden biri olan SchedulerControl nesnesinin kullanımı açıklamaya çalışacağım. Scheduler kontrol adındanda anlaşılacağı üzere tarihsel işlemleri görsel hale getirebileceğimiz detaylı bir kontroldür.zamanlamalı olarak randevu,görev,işlem vb. kavramları scheduler kontrol nesnesiyle kullanabiliriz.bunlarlada sınırlı değil tabiki.isterseniz Microsoft Outlook Takviminede bağlayabilir ve işlem kapsamınızı genişletebilirsiniz.Lafı fazla uzatmadan kodlamaya geçelim isterseniz. bu makaledeki bağlantı ve işlem şekilleri tamamen C# kodları ile yapılmaktadır.dataset vb. kontrolleri kullanmadım. yeni bir windows forms Projesi açalım ve boş bir forma schedulercontrol nesnesini sürükleyip bırakalım. kontrol ekranımıza yerleştiğinde alt kısımda SchedulerStorage isimli nesneyi göreceksiniz.SchedulerStorage SchedulerControl'ün çalışması için gerekli bir nesnedir zira veri işlemleri SchedulerStorage ...