1. Reklam


    1. joysro
      ledas
      jungler
      keasro
      zeus
      karantina

Data Access ve Data Controls


  1. Redefine

    Redefine Old School olduser rank8

    Kayıt:
    21 Kasım 2007
    Mesajlar:
    3.152
    Beğenilen Mesajlar:
    0
    Ödül Puanları:
    36

    *

    :arrow:Data Access ve Data Controls Sayfalarındaki Veritabanı Bileşenleri

    Bileşen paletinde Data Access ve Data Controls sayfalarında bulunurlar. Genel olarak bir veri tabanına bağlanıp veriler üzerinde insert, update,delete veya belli kayıtların görüntülenmesi için kullanılır. Bileşenler aşağıdaki şekillerde görülmektedir.

    [​IMG]

    [​IMG]

    Data Access sayfasındaki bileşenler unvisible (yani program çalıştığı zaman ekranda gözükmeyen) bileşenlerdir. Bu bileşenler Data Controls sayfasındaki bileşenler yardımı ile görüntülenecek veriler için veritabanları ile köprü vazifesi görürler.

    TTable: En önemli iki özelliği Database Name’i ve Table Name’dir. Database Name’e BDE içinden tanımladığınız herhangi bir alias’ı, projeniz içindeki Database bileşeninin Database Name’ini (bunlar combobox içinde otomatik olarak gelirler) veya paradox vb. gibi tablolar için tabloların bulunduğu dizinin adını verebilirsiniz. Bu bileşenin diğer önemli özelliklerinden biri de Index Name-Index Fields özelliğidir. Bu özelliği herhangi bir kayıta ulaşmak için kullanılır. Herhangi bir kayıta ulaşmak veya istenilen bir kayıtı bulmak için genel olarak üç çeşit yöntem kullanılır. Bunlar;


    1-)FindKey()
    2-)Locate()
    3-)Lookup()


    prosedürleridir. Birbirinden farkları şudur. Eğer findkey’i kullanıyorsanız index name ve index fields özellikleri belirtilmiş olmalıdır. Bu fonksiyon istenilen kayıt bulunmuşsa True aksi halde False değerini döndürür. Kullanılışı şu şekildedir :

    Table1.FindKey([değişken1,değişken2,…]) gibi. Buradaki değişken sayısı index fields özelliğinde tanımlanan veya index name ile belirtilen indexin sahip olduğu alan sayısına eşit olmalıdır ve o alanlara karşılık gelen değerler verilmelidir.

    Örnek: Index Fields=Numara olsun. Bu durumda kod şu şekilde olmalıdır. Table1.FindKey([2500]) gibi. Burada indekste belirtilen alanın tipi ile koda yazdığımız tip birbirini tutmalıdır. Eğer Index Fields=Adi;Soyadi şeklinde ise kod Table1.FindKey([‘Ahmet’,’SAVAŞ’]) şeklinde olmalıdır.

    Locate prosedürü de FindKey gibi çalışır. Fakat bunda alan isimlerini de kendiniz verirsiniz. Eğer belirlediğiniz alanlara ait bir index varsa kullanılır, yoksa sıralı arama yapılır. Kullanılışı:

    Table1.Locate(‘adi;soyadi’,VarArrayof([‘Ahmet’,’SAVAŞ’]),[loCaseInsensitive,loPartialKey]) şeklindedir.


    loCaseInsensitive: Büyük harf-küçük harf ayrımı yapılmaz.

    loPartialKey:Bunu kullanırsanız eğer sadece SAVAŞ’ı değilde eğer SAVAŞÇI da varsa onuda bulabilirsiniz.

    Lookup da aynı şekildedir. Farklı yanı ise şudur; FindKey ve Locate de cursor bulunan kayıtın üstüne gider, lookup da ise nerde iseniz orda durur. Bir de bu fanksiyonları kullanırken dikkat edeceğiniz diğer bir husus en son yaptığınız işlemdir. Bu prosedürlerden herhangi birini çağırdığınız zaman en son yapılan işlem otomatik olarak kaydedilir. Örneğin iptal etmeniz gereken bir işlem varsa veya tablo insert modundaysa bu durumlarıda kontrol etmelisiniz. Diğer sık kullanılan prosedürleri ise Edit, Insert, Post’dur.

    Tablonun hangi durumda olduğunu Table1.State ile öğrenebilirsiniz. Örneğin Table1.State in [dsEdit] tablonun edit modunda olduğunu gösterir.


    TQuery: Bu bileşende TTable bileşeni ile hemen hemen aynıdır. Fakat bu bileşen ve SQL yardımı ile kayıtlar üzerinde sıralama, sadece belli kayıtları görüntüleme vb. işlemler çok daha rahat yapılabilmektedir. Aynı şeyler TTable bileşenin Filter, Range gibi özellikleri kullanılarak da yapılabilir. Fakat, performans açısından bakıldığında TQuery’leri kullanmak her zaman faydalıdır. Query’ler normalde Read-Only’dirler, yani kayıtlar üzerinde değişiklik yapamazsınız. Eğer kayıtlar üzerinde değişiklik yapmak istiyorsanız, RequestLive özelliğini True yapmalısınız. Bu şekilde kayıtlar üzerinde değişiklik yapıp, yapılan değişiklikleri table'da olduğu gibi kaydedebilirsiniz. Fakat SQL cümleciğiniz birkaç tablodan veri alıp getiriyorsa o zaman RequestLive özelliğini kullanmazsınız. Bu şekildeki query’ler üzerinde değişiklik yapabilmeniz için önce CachedUpdates özelliğini True yapmalısınız. (Bu arada RequestLive, False olmalıdır.) CachedUpdates özelliği True yapıldığında kayıtlar üzerinde güncelleme, değiştirme ve silme yapabildiğinizi göreceksiniz. Fakat bu değişiklikler sadece programda kalır ve fiziksel veritabanını etkilemez. Yaptığımız değişikliklerin kalıcı olması olması için TUpdateSQL bileşenini kullanırız.Bu işlem için aşağıdaki adımları takip etmelisiniz.

    .TQuery ve TUpdateSQL bileşenlerini yerleştirin
    .TQuery’nin SQL ifadesini yazın.
    .TQuery’nin UpdateQbject özelliğini UpdateSQL1 olarak seçin(veya ne isim verdiyseniz)
    .UpdateSQL1 bileşeninin seçip mouse’un sağ tuşuna basın. Oradan UpdateSQL Editor…’ü tıklayın. Aşağıdaki ekran karşınıza gelecek.

    [​IMG]

    İlk önce üzerinde değişiklik yapmak istediğiniz tabloyu seçmelisiniz. Daha sonra Key Fields ile belirtilen genellikle sizin üzerinde değişiklik yapmadığınız alanlar seçilmelidir. Numara vb. Daha sonra değiştirilecek alanlar Update Fields da belirtilen alanlardan seçilmelidir. Daha sonra ise Generate SQL butonuna bastığınızda sizin için gerekli SQL’lerin oluştuğunu göreceksiniz. Daha sonra kod içinde istediğiniz herhangi bir yerde UpdateSQL1.ExecSQL() prosedürünü kullanarak yaptığımız işlemin kalıcı olmasını sağlayabiliriz. ExecSQL’in alacağı parametreler;

    ukModify : Güncelleme işleminin kalıcı olması için

    ukInsert : Yeni girilen bir kayıtın veritabanında olması için

    ukDelete : Sildğiniz bir kayıtın veritabanından da silinmesi için. TTable üzerinde geçerli olan işlemlerin birçoğu TQuery içinde geçerlidir.


    TStoredProc: Bu bileşen SQL tabanlı veritabanları üzerinde yazdığınız prosedürleri veya fonksiyonları kullanmanızı sağlayan bir bileşendir. Eğer Oracle, Sysbase, SQL Server gibi veritabanı kullanmıyorsanız bu bileşene ihtiyacınız yok demektir. Fakat adı anılanlardan herhangi biri veya bunlara benzer bir veritabanı sistemi kullanıyorsanız bu bileşen çok işinize yarayacaktır. Avantajları temel olarak şunlardır. Bu çalıştıracağınız prosedürler veritabanı üzerindedir. Normal kullandığınız query’lere göre çok daha hızlı çalışırlar. Network trafiğini asgari seviyeye indirirler. Yazacağınız prosedürle ilgili kullandığınız veritabanının dökümatasyonuna bakmalısınız.

    Örn: Oracle’da prosedür şöyle olsun.

    PROSEDURE TEST (ISIM OUT VARHAR2, NUMARA NUMBER) IS
    BEGIN
    SELECT ADI INTO :ISIM FROM ABONE WHERE ABONE_NO=:NUMARA;
    END;

    Bunu Delphi’de aşağıdaki gibi kullanabilirsiniz;

    StoredProc1.ParamByName(‘Numara’).Value:=’1000’;
    StoredProc1.GetResults;
    Abone_Ismi:= StoredProc1.ParamByName(‘Isim’).AsString;

    TDatabase: Bu bileşeni projeniz içinde yönetim kolaylığı sağlamak için kullanabilirsiniz. Mesela TEST diye BDE alias’ınız var. Projedeki bütün table’lar query’ler vs. hepsi buna bağlı. Bunun ismini değiştirdiğinizde bütün projede gidip aliasları değiştirmeniz gerekir. Bunun yerine TDatabase bileşenini kullanırsanız, sadece bu bileşenin alias’ını değiştirdiğinizde projede buna bağlı ne kadar bileşen varsa hepsini etkileyecektir.


    [​IMG]

    şeklinde olabilir.

    TDataSource: Verilerinizin data controls sayfasındaki bileşenler yardımı ile görüntülenmesi için table,query vb. gibi datasetleri mutlaka bir DataSource’a bağlamnız gerekir.

    Data Controls:

    TDBGrid: Verilerin gösterilmesi için kullanılır. Gösterilecek alanlar ayarlanabilir, verilerin fontu ve grid’in başlık fontu ayrı ayrı ayarlanabilir.

    TDBNavigator: Veriler üzerinde güncelleme, silme, yeni kayıt, ileri-geri gitme vs. gibi işlemlerin yapıldığı araç çubuğudur. Bunu bir datasource’a bağladığınız zaman bu datasource’un bağlı olduğu dataset navigator de yaptığınız tüm işlemlerden etkilenir.

    TDBText: Label ile aynıdır. Fakat bağlı olduğu tablodan belirtilen alan bilgisini görüntüler. Genelde üzerinde değişiklik yapılmaycak alanların gösterilmesi için uygundur.

    TDBEdit: DBText ile benzerdir, ek olarak eğer imkan dahilinde ise veriler üzerinde değişiklik yapılabilir.

    TDBMemo: Birden fazla satırın yada 255 karakterden daha uzun verilerin saklanması ve gösterilmesi için kullanılır.

    TDBImage: Veritabanlarında resim içeren alanların işlenmesi için kullanılır.

    TDBListBox: Bunun özelliği şudur. Verdiğiniz alan değeri eğer listeni içinde bulunuyorsa otomatik olarak seçilir. Bileşenin listesini siz kendiniz doldurmak zorundasınız. Verdiğiniz alan ile ilgili değerler otomatik olarak gelmez. Mesela listesi Table1’in Isim alanına bağladınız. Etkin kayıttaki isim ‘Ahmet’ ve liste elemanları içinde de ‘Ahmet’ varsa bu eleman otomatik olarak işaretlenir. Aksi halde yani liste elemanları içinde ‘Ahmet’ yoksa listede hiçbir eleman işaretlenmez. Büyük-küçük harf farketmez.

    TDBComboBox: TListBox ile aynıdır. Eğer elemanları arasında etkin kaydın ilgili değeri varsa görüntülenir, diğer halde boş olarak gözükür.

    TDBCheckBox: Genelde iki durumlu veriler için kullanılır. Mesela, personel tablosu için düşünecek olursanız kişi yönetici veya değil. Bunun için kullanılabilir. Yönetici olması 1, olmaması 0 ile gösterilecek olursa ValueChecked=1, ValueUnChecked=0 olmalıdır. Eğer veriyi sadece göstermek amacı ile bu bileşeni göstermek kullanmak isterseniz o zaman ValueChecked ve ValueUnChecked özelliklerine birden fazla değer girebilirsiniz. Mesela 2 üst düzey yöneticiyi göstersin. Eğer detay gerekmiyorsa yönetici olduğunu göstermek için ValueChecked=1;2 şeklinde değer girebilirsiniz.

    TDBRadioGroup: Bu bileşen tablolarda kod olarak tutulan fakat programda açık olarak yazılması gereken alanlar için kullanılır. Mesala, 0-İşçi, 1-Yönetici, 2-Üst düzey yönetici ise bu bileşenin Items özelliğine alt alta İşçi, Yönetici ve Üst Düzey Yönetici, Values özelliğine de yine alt alta 0,1 ve 2 yazarsanız veritabanında 0 olduğu zaman İşçi, 1 olduğu zaman Yönetici ve 2 olduğu zaman Üst Düzey Yönetici otomatik olarak RadioGroup içinde seçilecektir. Aynı bunları yeni veri girişi yaparken de kullanabilirsiniz. (Son kullanıcılar personelin durumunu girerken 0’dan pek bişey anlamazlar. :) )

    TDBLookupListBox: Bu bileşen başka bir tablonun belirtilen alanında bulunan tüm verileri görmek ve aynı zamanda istenirse bu verilerle ilgili bilgileri başka bir tabloya kaydetmek için kullanılır. Örn: Personel tablonuzda personelin oturduğu il kodunu tutuyorsunuz. Bunun için birde IlKodu,IlAdı’nı içeren Iller tablonuz var. O zaman bu bileşenin Datasource’u olarak personel, datafield’i ilkodu, ListSource’u ıller, listFields’ı il_adi ve keyField’i da ıl_kodu verdiğiniz zaman illerden Ankara’yı seçtiğiniz zaman personelin ilkodu alanına ‘06’ otomatik olarak yazılacaktır. Aynı şekilde ilkodu ‘34’ olan bir personelde Illerden İstanbul otomatik olarak seçilektir.

    TDBLookupComboBox: TDBLookupListBox ile aynıdır.

    TDBRichEdit: Eğer veritablarında 64Kb’den daha büyük bilgini işlenmesi gerekiyor bu bileşen kullanılır.

    TDBCtrlGrid: DBGrid gibidir. Fakat bunda her bir kayıtın için gösterilicek alanları, bu olanların nasıl gösterileceğini (herbiri ayrı bir renkte, farklı büyüklükte gibi) belirleyebilirsiniz.

    TDBChart: Veritabanındaki verilerden otomatik grafik oluşturmak için kullanılır.
     
  2. Band'Eros

    Band'Eros Öğretiyorum rank8

    Kayıt:
    18 Ocak 2009
    Mesajlar:
    933
    Beğenilen Mesajlar:
    0
    Ödül Puanları:
    0
    alıntı değilse süper bence :D eline sağlık :thumbsup: :headbang: