25 Ağustos 2008 Pazartesi

ComboBox Kontrolünün AutoComplete Özelliği

Bu Makalemizde ComboBox un AutoComploteMode Özelliğini kullanarak ComboBox kontrol kutusuna veri tabanımızdaki bilgileri otomatik olarak nasıl yazdıracağımızı irdeliyeceğiz.

AutoCompleteMode - Suggest ComboBox daki bilgieri harf katarına göre sıralar ve liste halinde Gösterir.

AutoCompleteMode - Append ComboBox daki bilgileri harf katarına göre ComboBox u doldurur.

AutoCompleteMode - SuggestAppent Her iki özelliği birden kullanır.

ÖRNEK :

Formumuza eklediğimiz ComboBox Kontrol Kutusunun...

1 . DataSource özelliğini ayarlayın.

2. AutoCompleteMode - özelliğini SuggestAppent olarak ayarlayın

3. AutoComploteSource - özelliğini ListItems olarak ayarlayın

Çalışmalarınızda başarılar diler Saygılarımı sunarım..

Etiketler:

SqlConnectionString Parametreleri

ConnectionString Veri kaynağına bağlantı sağlayabilmesi için gerekli olan tüm parametreleri tanımlar. Bu parametreler şunlardır:

PROVİDER --- Sadece OLE DB veri sağlayıcısı için kullanılır. Kullanılacak Sağlayıcıyı belirler.

DATASOURCE - SERVER --- Bağlanacak Sunucunun adını belirler. serverin adı yazılmalıdır.

INITIAL CATOLOG / DATABASE --- Bağlanacak veritabanını belirler. Veritabanının dosyayolu ve adı yazlımalıdır.

INTEGRATED - TRUSTED_CONNECTİON --- Güvenli bir bağlantı kullanılıp kullanılmayacağını belirler. Varsayılan değeri FALSE dir. Bu değerin TRUE yada SSPI olması aynı anlama gelir. SSPI (Secuirty Service Provider Interface) veri kaynağına güvenli olarak bağlanacağını belirler.

USER ID --- Kullanıcı Giriş hesabı adı belirler.

USER PASSWORD - PWD --- Kullanıcı giriş hesabı şifresi belirler.

PERSIST SECURITY INFO --- Hassas güvenlik bilgilerinin bağlantı ifadesinin bir parçası olarak geriye gönderilip gönderilmeyeceğini belirler.

CONNECT TIMEOUT - CONNECTION TIMEOUT --- Bağlantının sağlanması için sunucunun hata üretmeden bekleyeceği süreyi belirler. Varsayılan değeri 15 saniyedir.

Bir ConnectionString Nasıl Tanımlanır ?

ConnectionString Özelliği veri kaynağı için kullanılan bağlantının kapalı olması durumunda kullanılır.

ConnectionString içinde tanımlanan her bir ifade noktalı virgül ile (;) ayrılmak zorundadır.

Örnek:

"DataSource= SunucuAdı;Integrated Security = SSPI; Initial Catalog= Veritabanının Adı"

Not: Bu bilgiler Zeydin PALA nın Visual Basic.NET kitabından alıntıdır.

Etiketler:

Kayıtlar arasında gezinme silme ekleme ve güncelleme yapmak için kullanabileceğimiz nesnelerden birisidir.

Öncelikle veritabanımızın bağlantılarını yapıyoruz…


Dim DS as Dataset
Dim Adp AS SqlDataAdapter
Dim BindingSource1 as BindingSource
Dim SqlConn As SqlConnection = New SqlConnection("Data Source=SERVERADI;AttachDbFilename=DataDirectory\VERİTABANININADI;Integrated Security=True;Connect Timeout=30;User Instance=True")

Try
ADP = New SqlDataAdapter("SELECT * FROM TabloAdı", SqlConn)
SqlConn.Open()
ADP.Fill(DS, "TabloAdı")

‘BindingSource nesnesini datasete bağlıyoruz..
BindingSource1 = New BindingSource(DS, "TabloAdı")
Catch ex As Exception
System.Windows.Forms.MessageBox.Show(ex.Message)
Finally
SqlConn.Close()
End Try


‘BindingSource de bulunan bilgileri verileri textbox kutularına aktarmak için CURRENT Metodunu kullanıyoruz..
COUNT Metodu kayıt sayısını verir. Eğer 0 (Sıfır ) ise Kayıt Yoktur..

if BindingSource1.Count <> 0 then
‘Veri Tabanında kayıt varsa…
TextBox1.Text = BindingSource1.Current(“AlanAdı1”)
TextBox2.Text = BindingSource1.Current(“AlanAdı2”)
TextBox3.Text = BindingSource1.Current(“AlanAdı3”)

End if

‘Kayıtlar arasında gezinmek için…
BindingSource1.MoveNext ‘Sonraki Kayıt
BindingSource1.MoveLast ‘Son Kayıt
BindingSource1.MoveFirst ‘İlk Kayıt
BindingSource1.MovePrevious ’Önceki Kayıt

‘Yeni Kayıt Eklemek için ADDNEW Metodunu kullanıyoruz..
BindingSource1.AddNew

‘Kayıt Silmek için RemoveAt(indis) Metodunu kullanıyoruz..
BindingSource1.RemoveAt(SilinecekKaydınNumarası)

‘filitreleme yapmak için FILTER Metodunu kullanıyoruz..
BindingSource1.Filter = "Alan1 = '" & FilitrelenecekBilgi & "'"

‘Harf katarına göre filitreleme yapmak istersek LIKE operatöünü kullanabiliriz..
BindingSource1.Filter = "Alan1 LIKE '" & FilitrelenecekBilgi & "%'"

‘Arama Yapmak için FIND Metodunu kullanıyoruz..
‘Aramayı Filitrelenen kayıtlarda yapar. Eğer tüm kayıtlarda arama yapmasını istiyorsak ve daha önceden filitreme yaptıysak ilk olarak filitrelemeyi iptal etmeliyiz..
BindingSource1.RemoveFilter

‘POSITION Metodu kaydın numarasını verir. bulunan kaydın aktif kayıt olması için kullanıyoruz..
BindingSource1.Position=Bindingsource1.Find(“AranılacakAlanAdı”,AranılacakBilgi)

‘Position Metodu -1 (EksiBir) değerini alırsa aranılan kayıt yoktur.

if BindingSource1.Position = - 1 then
Msgbox(“Aradığınız Kayıt Yoktur”)
Else
Msgbox (BindingSource1.Current(“Alan1”) & “ ” & BindingSource1.Current(“Alan1”) & “ ” & BindingSource1.Current(“Alan1”))
End if


‘Kayıt Güncellemek için

BindingSource1.Current(“AlanAdı1”) = TextBox1.Text
BindingSource1.Current(“AlanAdı2”) = TextBox2.Text
BindingSource1.Current(“AlanAdı3”) = TextBox3.Text


‘Güncelleme Tamamlandıktan sonra ENDEDIT Metodunu kullanıyoruz..
BindingSource.EndEdit

‘Veri Tabanını Güncellemek için..
Adp.Update(DS,”TabloAdı”)


İYİ ÇALIŞMALAR

Etiketler: , , , , , , , ,

Collection Nesnesi

Collection nesnesi Visual Basic dizilerinin nesne yönelimli bir uygulamasıdır. Bununla beraber nesnel olmayan verileri de saklama yeteneğine sahiptir. For…Each…Next yapısı ile nesnenin tüm elemanlarına ulaşılabilir.
Koleksiyona herhangi bir anda ve herhangi bir sırada yeni eleman eklemek mümkündür. Elemanların indisleri otomatik olarak VB tarafından yapılmaktadır. Koleksiyon elemanlarına kendilerine verilen anahtar kelimeler ile ulaşılır.
Collection nesnesi Collection.Add, Collection.Count, Collection.Item, Collection.Remove olmak üzere dört metodu destekler.

Aşağıdaki biçimde kullanılır.

Dim NesneninDeğişkenAdi As New Collection

Örnek:

Dim Urunler As New Collection
Yada;
Dim Urunlar As Collection
Urunler=New Collection


Collection.Add :
Collection Nesnesine yeni bir eleman ekler.
NesneninDeğişkenAdi.Add(ElemanAdi,[,Anahtar,Once,Sonra])

ElemanAdi Kolleksiyone eklenecek elemanın adıdır.
Once Kullanması zorunlu değildir. Listedeki hangi elemandan önce yer alacağını belirtir.
Sonra Kullanması zorunlu değildir. Listedeki hangi elemandan Sonra yer alacağını belirtir.

Örnek :
Dim Urunlar As New Collection
Urunler.Add(“Bilgisayar”)
Urunler.Add(“Telefon”)
Urunler.Add(“Ev Elektironiği”)


İstersek koleksiyondaki elemanlara benzersiz birer tane anahtar kelimede verebiliriz.

Dim Urunlar As New Collection
Urunler.Add(“Bilgisayar”,”pc”)
Urunler.Add(“Telefon”,tel”)
Urunler.Add(“Ev Elektironiği”,”elk”)


Araya Eleman Ekleme :
Aşağıda verilen kullanımda üçüncü satırda işleme giren eleman kollection içinde ikinci sırada yer alacaktır.

Dim Urunlar As New Collection
Urunler.Add(“Bilgisayar”,”pc”)
Urunler.Add(“Telefon”,tel”)
Urunler.Add(“Ev Elektironiği”,”elk”,”tel”)


Koleksiyonun tüm elemanları For…Each…Next döngüsü ile debug penceresine yazdıralım…

For Each n In Urunler
Debug.WriteLine(n)
Next


Eğer eklenecek eleman için önce ve sonra parametreleri kullanılmaza yeni eleman koleksiyonun en sonunda yer alacaktır.

Eğer eklenen elemana anahtar kelime verilmez ise o elemana anahtar kelime ile ulaşılamaz.

Collection.Remove :

Koleksiyon içinde indisi veya anahtar kelimesi verilen elemanı siler.
NesneninDeğişkenAdi.Remove(indis)
NesneninDeğişkenAdi.Remove(anahtar)


Örnek:
Urunler.Remove(1)
Urunler.Remove(“tel”)


Collection.Count :
Koleksiyonun eleman sayısını bulur. Sayı 1 (Bir) den başlar.
MsgBox(urunler.Count)

Collection.Item :
Koleksiyon içinde indisi verilen elemanı bulur.
NesneninDeğişkenAdı.Item(indis)

MsgBox(Urunler.Item(1))
MsgBox(Urunler.Item(2))


Koleksiyon içinde arama yapar.
NesneninDeğişkenAdı.Contains("AranacakIndis")

İyi Çalışmalar.

Etiketler:

DataGridView Satırlarını Renklendirme

DataGridView'in RowPrePaint Eventine aşağıdaki kodları yazalım...

Private

Sub DataGridView1_RowPrePaint(ByVal sender As Object, ByVal e As System.Windows.Forms.DataGridViewRowPrePaintEventArgs) Handles

DataGridView1.RowPrePaint

Dim satir As DataGridViewRow = Me.DataGridView1.Rows(e.RowIndex)

Dim sayi As Integer

sayi = Val(e.RowIndex) Mod 2

If sayi = 0 Then

satir.DefaultCellStyle.BackColor = Color.Beige

Else

satir.DefaultCellStyle.BackColor = Color.Azure

End If

End Sub

Etiketler: , , ,