Come ordinare i record in Delphi DBGrid

Delphi DBGrid è un componente così potente che probabilmente lo stai usando ogni giorno se stai sviluppando applicazioni sensibili ai dati. Di seguito, daremo un'occhiata a come aggiungere altre funzionalità alle applicazioni del database che gli utenti apprezzeranno sicuramente.

Seguendo i concetti descritti nella Guida per principianti alla programmazione del database Delphi, gli esempi seguenti utilizzano componenti ADO (AdoQuery / AdoTable collegati ad ADOConnection, DBGrid connesso ad AdoQuery su DataSource) per visualizzare i record da una tabella di database in un componente DBGrid.

Tutti i nomi dei componenti sono stati lasciati come Delphi li ha nominati quando rilasciati sul modulo (DBGrid1, ADOQuery1, AdoTable1, ecc.).

Il mouse si sposta sull'area del titolo DBGrid

Innanzitutto, vediamo come modificare il puntatore del mouse mentre si sposta sull'area del titolo DBGrid. Tutto quello che devi fare è aggiungere il codice all'evento OnMouseMove per il componente DBGrid.

Il codice seguente utilizza semplicemente la proprietà MouseCoord del componente DBGrid per "calcolare" la posizione del puntatore del mouse. Se si trova sopra l'area del titolo DGBrid, il pt.y è uguale a 0, che è la prima riga nel DBGrid (l'area del titolo che mostra i titoli di colonna / campo).

procedura TForm1.DBGrid1MouseMove
(Mittente: TObject; Maiusc: TShiftState; X, Y: intero);
var
pt: TGridcoord;
inizio
pt: = DBGrid1.MouseCoord (x, y);
Se pt.y = 0 poi
DBGrid1.Cursor: = crHandPoint
altro
DBGrid1.Cursor: = crDefault;
fine;

Ordina su colonna Fare clic e modificare il carattere del titolo della colonna

Se si utilizza l'approccio ADO allo sviluppo del database Delphi e si desidera ordinare i record nel set di dati, è necessario impostare la proprietà Sort del proprio AdoDataset (ADOQuery, AdoTable).

La proprietà Sort è il valore allargato che indica la parte "ORDER BY" della query SQL standard. Ovviamente, non è necessario scrivere la query SQL per poter utilizzare la proprietà Sort. Basta impostare la proprietà Sort sul nome di un singolo campo o su un elenco di campi separato da virgole, ognuno seguendo il criterio di ordinamento.

Ecco un esempio:

ADOTable1.Sort: = 'Anno DESC, ArticleDate ASC'

L'evento OnTitleClick del componente DBGrid ha un parametro Column che indica la colonna su cui l'utente ha fatto clic. Ogni colonna (oggetto di tipo TColumn) ha una proprietà Field che indica il Field (TField) rappresentato dalla colonna e il Field nella sua proprietà FieldName contiene il nome del campo nel set di dati sottostante.

Pertanto, per ordinare un set di dati ADO per campo / colonna, è possibile utilizzare una riga semplice:

con TCustomADODataSet (DBGrid1.DataSource.DataSet)
Ordina: = Column.Field.FieldName; // + 'ASC' o 'DESC'

Di seguito è riportato il codice per il gestore uniforme di OnTitleClick che ordina i record per clic sulla colonna. Il codice, come sempre, estende l'idea.

Innanzitutto, vogliamo in qualche modo contrassegnare la colonna attualmente utilizzata per l'ordinamento. Quindi, se facciamo clic sul titolo di una colonna e il set di dati è già ordinato per quella colonna, vogliamo cambiare l'ordinamento da ASC (crescente) a DESC (decrescente) e viceversa. Infine, quando ordiniamo il set di dati per un'altra colonna, vogliamo rimuovere il segno dalla colonna precedentemente selezionata.

Per semplicità, per contrassegnare la colonna che "ordina" i record, cambieremo semplicemente lo stile del carattere del titolo della colonna in Grassetto e lo rimuoveremo quando il set di dati viene ordinato usando un'altra colonna.

procedura TForm1.DBGrid1TitleClick (Column: TColumn);
$ J +const PreviousColumnIndex: intero = -1;
$ J-
beginif DBGrid1.DataSource.DataSet è TCustomADODataSet thenwith TCustomADODataSet (DBGrid1.DataSource.DataSet) dobegintry
DBGrid1.Columns [PreviousColumnIndex] .title.Font.Style: =
DBGrid1.Columns [PreviousColumnIndex] .title.Font.Style - [fsBold];
exceptend;
Column.title.Font.Style: =
Column.title.Font.Style + [fsBold];
PreviousColumnIndex: = Column.Index;
Se (Pos (Column.Field.FieldName, Sort) = 1)
e (Pos ('DESC', ordinamento) = 0) poi
Ordina: = Column.Field.FieldName + 'DESC'
altro
Ordina: = Column.Field.FieldName + 'ASC';
fine;
fine;

Il codice sopra utilizza costanti tipizzate per conservare il valore della colonna "selezionata" in precedenza per l'ordinamento.