Ana içeriğe atla

Nasıl Yapılır ? - DataTable İçerisinde Arama Yapmak ve Hücre Değerlerini Değiştirmek

merhaba;

bazen gridcontrol içerisindeki verilerde değişiklik yapmak isteyebiliriz.bu işlem için birden fazla yöntem bulunmakla birlikte bu makale bu işlemi en basit ve farklı bir yoldan nasıl yapabiliriz onu açıklamaya çalışacağım.


gridcontrol içerisindeki verileri değiştirmek için izlenebilecek yollardan bir tanesi T-SQL sorgusunu değiştirmektir.

örnek vermek gerekirse bir ürün tablomuz olsun.bu ürün tablomuzda ürünün geldiği şehir id si bulunsun.şehir tablosundada ilgili id nin şehir adı bulunsun.normalde t-sql sorgusu ile bunu joinlerle yapabiliriz fakat eğer çok fazla join işlemi bulunuyorsa bu sorguyu birden fazla alt sorgu haline getirmek ve dönen kayıtları tek datatable içerisinde toplamak gerekebilirken aşağıda anlatacağım yöntem ile bunu basitçe halledebiliriz.


ben kodlama işlemine; sizin verilerinizi çekip,datatable içerisine aktardığınızı varsayarak başlıyorum;

1-DataTable içerisinde arama
int sayac = 0;
            foreach (DataRow dr in tablo.Rows)
            {
             
                string sehir = db.Valreturn("select ADI from il where ID='" + dr["sehir"].ToString() + "'");
                db.tablo.Rows[sayac][db.tablo.Columns["sehir"]] = sehir;
                sayac++;
       
            }



yukarıdaki örnekte datatable içerisinde foreach döngüsü yardımıyla arama yaptık ve datatable içerisindeki her satır için id değerini aldığımız şehir bilgisini datatable'ın ilgili hücresine yazdık.yani önce
string sehir = db.Valreturn("select ADI from il where ID='" + dr["sehir"].ToString() + "'");
satırıyla datatable ın "sehir" kolonunda bulunan şehir id sini aldık ve şehir tablosundan ilgili id nin adı na ulaşıp bunu sehir değişkenine atadık.Daha Sonra;
db.tablo.Rows[sayac][db.tablo.Columns["sehir"]] = sehir;

satırıyla ilgili hücreyi değiştirerek id yerine şehir adının yazılmasını sağladık.
sayac++;
kodu ile de sayacı arttırarak bu işlemin tüm satırlar için yapılmasını sağladık.

isterseniz bu işlemi belirli değerler için de yapabilirsiniz örneğin ;


if (tablo.Rows[sayac][db.tablo.Columns["sehir"]] == "İzmir")
                {
\\ kodlar buraya
                }
şeklinde bir ifade kullanırsanız foreach içerisinde sehir bilgisi İzmir'e veya başka bir değere eşit olduğunda yapılacak işlemleri belirtebilirsiniz.


bu makalemin de sonuna gelmiş bulunuyorum.sağlıcakla kalın.

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

ASP.NET - Aynı anahtara sahip bir girdi zaten var.

Eğer ASP.NET ile uğraşırken böyle bir hata aldıysanız aşağıdaki paragraf tam size göre; " Aynı anahtara sahip bir girdi zaten var."  hatasının sebebi sayfanızdaki birden çok nesne için  ClientIDMode Özelliğini " Static " olarak ayarlamanızdan kaynaklanmaktadır.Normal şartlarda sayfa içerisindeki her kontrolün ID si birbirinden farklı olmalıdır.bu tanımı düzelttiğinizde sorununda çözüldüğünü göreceksiniz.Burdaki problem şu ki visual studio hatayı farklı satırlarda veriyor.buda özellikle ilk defa böyle bir hata ile karşılaşıyorsanız çözümü inanılmaz zorlaştırıyor.