Ana içeriğe atla

ADO.NET Veritabanı Bağlantı Nesneleri Yazı Dizisi 2 - SqlCommand

bu yazımızda SqlConnection nesnesi ile bağlantı kurduğumuz veritabanı üzerinde sorgulama işlemleri yapmamız için gerekli olan ado.net nesnelerinden SqlCommand nesnesi üzerinde duracağız.SqlCommand nesnesinin en temel özellikleri veritabanı üzerinde;

  1. Ekleme (INSERT)
  2. Silme (DELETE)
  3. Güncelleme (UPDATE)
  4. Seçme (SELECT)

gibi işlemleri yapabilmemize yarar.

Connection Özelliği;

SqlCommand nesnesinin hangi connection üzerinde çalıştığını belirlemek için kullanılır.SqlCommand nesnesi bağlantısı sağlanmış bir SqlConnection nesnesi üzerinden veritabanı işlemlerini gerçekleştirebilir.






connection nesnemizi yapılandıralım
SqlConnection baglanti=new SqlConnection();
baglanti.ConnectionString="Server=localhost;Port=3306;Database=candb;Uid=root";


nesne örneğimizi yaratalım ;
SqlCommand komut=new SqlCommand();

nesnemizin connection özelliğini kullanarak nesnemizi SqlConnection nesnemize bağlayalım;
komut.Connection=baglanti;


SqlCommand nesnemizin sorgu tipini belirtelim;
komut.CommandType=CommandType.Text;


Veritabanında işlemek istediğimiz sorgumuzu nesnemizin CommandText özelliğine Atayalım;
komut.CommandText="SELECT * FROM tabloadi";


buraya kadar yaptığımız işlemler sqlcommand nesnemizin bağlantısını ve çalıştırmak istediğimiz sorguyu set etmekten ibaret.şimdi yapacağımız işlemler ile sorgumuzun işlendikten sonra tarafımıza dönecek değerleri kontrol etmeye yarayacak.SqlCommand nesnemizin execute metodları ile yaptığımız işlemlerin sonuçlarını alabiliriz.(Döndürmek istediğimiz sorgu sonuçları gibi).

SqlCommand nesnemizin başlıca execute metodları;


  • ExecuteScalar();
  • ExecuteReader();
  • ExecuteNonQuery();
  • ExecuteXmlReader (): 

ExecuteScalar();Execute scalar metodu sqlcommand nesnemizin bize tek bir değer döndürmesini sağlar.

Kullanımı ;


komut.ExecuteScalar();



ExecuteReader();
Execute reader metodu Sqlcommand nesnemizin sorgu sonucunda dönen tüm değerleri tarafımıza iletmesi için kullanılır.

Kullanımı ;
komut.ExecuteReader();


ExecuteNonQuery();
Execute non query metodu Sqlcommand nesnemizden geriye değer dönmesini istemediğimizde kullanılır.insert update delete işlemlerinde tercih edilir.

Kullanımı ;
komut.ExecuteNonQuery();

ExecuteXmlReader ();
Bu metod kullanımında geriye dönen değer xml formatında olur. veritabanından XML formatlı değerler elde edebilmek için command nesnemizin bu özelliği kullanılır

Kullanımı ;
komut.ExecuteXmlReader ();


*command nesnemizden dönen değerleri değişkene atayarak kullanabilirsiniz

ayrıca sqlcommand nesnemizin parametre oluşturma özelliği ile veritabanı tipine uygun parametreler oluşturarak işlemlerimizi daha hızlı ve güvenli şekilde yapabiliriz.özellikle injection gibi konularda parametre kullanmak yararımıza olur.normal koşullarda inputları direk olarak sorgu içerisine aldığınızda (özellikle insert(ekleme) işlemlerinde) SqlCommand nesnesi kullanıcıdan almış olduğu değerin veritabanındaki kolon tipi ile uygun olup olmadığını kontrol etmektedir.fakat verilerinizi sqlcommand parametreleri içerisinde set ederseniz,girdiğiniz değer parametre tipine uygun değilse size hata verecektir.parametre kullanımı bence önemlidir.

parametre tanımlama ve değer aktarımı en basit şekilde;

cmd.Parameters.Add("@Name", SqlDbType.VarChar, 50).Value = "Can Çevikoğlu";
şeklinde yapılır.

Bir sonraki Yazımızda görüşmek üzere hepinize iyi çalışmalar.

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 ...