Delphi DBGrid on nii võimas komponent, et kasutate seda tõenäoliselt iga päev, kui arendate andmeteadlikke rakendusi. Allpool vaatame, kuidas lisada andmebaasirakendustele veel mõned funktsioonid, mida teie kasutajad kindlasti armastavad.
Järgides artiklis Delphi andmebaaside programmeerimise algajad, kasutavad alltoodud näited ADO komponente (AdoQuery / AdoTable ühendatud ADOConnectioniga, DBGrid on ühendatud AdoQueryga DataSource'i kaudu) arvestust andmebaasitabelist DBGrid-komponendis.
Kõik komponentide nimed jäid alles, kuna Delphi nimetas need vormile langemisel (DBGrid1, ADOQuery1, AdoTable1 jne).
Hiir liigub üle DBGridi pealkirjaala
Esiteks vaatame, kuidas muuta hiirekursorit, kui see liigub üle DBGridi tiitlipiirkonna. Teil on vaja vaid lisada kood DBGrid-komponendi sündmusele OnMouseMove.
Allolev kood kasutab lihtsalt DBGridi komponendi MouseCoordi omadust hiirekursori "arvutamiseks". Kui see asub üle DGBridi tiitlipiirkonna, võrdub pt.y 0-ga, mis on DBGrid-i esimene rida (tiitrite ala, kus kuvatakse veeru / väljade pealkirjad).
protseduur TForm1.DBGrid1MouseMove
(Saatja: TObject; Shift: TShiftState; X, Y: täisarv);
var
pt: TGridcoord;
alustada
pt: = DBGrid1.MouseCoord (x, y);
kui pt.y = 0 siis
DBGrid1.Kursor: = crHandPoint
muud
DBGrid1.Cursor: = crDefault;
lõpp;
Sordi veeru järgi Klõpsake ja muutke veeru pealkirja fonti
Kui kasutate ADO-lähenemist Delphi andmebaasi arendamiseks ja soovite sortida kirjeid andmekogumis, peate määrama oma AdoDataset'i omaduse Sorteeri (ADOQuery, AdoTable).
Omadus Sorteerimine on lairiba väärtus, mis näitab standardses SQL päringus osa "ORDER BY". Loomulikult ei pea Sorteerimise omaduse kasutamiseks SQL-päringut kirjutama. Valige lihtsalt sortimise atribuut üksiku välja nimeks või komaeraldusega väljade loendiks, järgides iga sortimisjärjestust.
Siin on näide:
ADOTable1.Sort: = 'Aasta DESC, ArticleDate ASC'
Komponendi DBGrid OnTitleClicki sündmusel on veeruparameeter, mis näitab veergu, mille kasutaja on klõpsanud. Igal veerul (tüüp TColumn tüüp) on välja omadus Välja, mis näitab välja (TField), mida tähistab veerg ja omadus FieldName väli Field tähistab selle all oleva välja nime andmestik.
Seetõttu saab ADO andmestiku sortimiseks välja / veeru järgi kasutada lihtsat joont:
koos TCustomADODataSet'iga (DBGrid1.DataSource. DataSet) tegema
Sorteeri: = veerg. Väli. Välja nimi; // + 'ASC' või 'DESC'
Allpool on isegi OnTitleClicki käitleja kood, mis sorteerib kirjed veeru klõpsamise järgi. Kood laiendab ideed, nagu alati.
Esiteks tahame mingil viisil märkida veeru, mida praegu kasutatakse sortimisjärjestuse jaoks. Järgmisena, kui klõpsame veeru pealkirjal ja andmekogum on selle veeru järgi juba sorteeritud, tahame muuta sortimisjärjestuse ASC-st (kasvavalt) väärtuseks DESC (kahanevalt) ja vastupidi. Lõpuks, kui sortime andmestikku mõne teise veeru järgi, tahame eemaldada märgi varem valitud veerust.
Kirjeid sorteeriva veeru märkimiseks muudame lihtsuse huvides veeru pealkirja fondi stiili lihtsalt paksuks ja eemaldame selle, kui andmekogumit sorteeritakse mõne muu veeru abil.
protseduur TForm1.DBGrid1TitleClick (veerg: TColumn);
{$ J +}const PreviousColumnIndex: täisarv = -1;
{$ J-}
algav DBGrid1.DataSource. DataSet on TCustomADODataSet siis koos sellega TCustomADODataSet (DBGrid1.DataSource. DataSet) dobegintry
DBGrid1.Columns [PreviousColumnIndex] .title. Font. Stiil: =
DBGrid1.Columns [PreviousColumnIndex] .title. Font. Stiil - [fsBold];
erandama;
Veerg.title. Font. Stiil: =
Veerg.title. Font. Stiil + [fsBold];
PreviousColumnIndex: = Veerg. Indeks;
kui (Pos (veerg. Väli. Välja nimi, sort) = 1)
ja (Pos ('DESC', Sorteeri) = 0) siis
Sorteeri: = veerg. Väli. FieldName + 'DESC'
muud
Sorteeri: = veerg. Väli. Välja nimi + 'ASC';
lõpp;
lõpp;
Ülaltoodud kood kasutab trükitud konstandid et säilitada eelnevalt valitud veeru väärtus sortimisjärjestuses.