Το στοιχείο TADOQuery παρέχει Δελφοί προγραμματιστές τη δυνατότητα ανάκτησης δεδομένων από έναν ή περισσότερους πίνακες από ένα Βάση δεδομένων ADO χρησιμοποιώντας SQL.
Αυτές οι δηλώσεις SQL μπορούν είτε να είναι δηλώσεις DDL (Data Definition Language) όπως CREATE TABLE, ALTER INDEX, και ούτω καθεξής, ή μπορεί να είναι δηλώσεις DML (Language Manipulation Language), όπως SELECT, UPDATE και ΔΙΑΓΡΑΦΩ. Η πιο συνηθισμένη δήλωση, ωστόσο, είναι η πρόταση SELECT, η οποία παράγει μια προβολή παρόμοια με αυτήν που είναι διαθέσιμη χρησιμοποιώντας ένα στοιχείο πίνακα.
Σημείωση: παρόλο που είναι δυνατή η εκτέλεση εντολών χρησιμοποιώντας το στοιχείο ADOQuery, το ADOC εντολήσυστατικό είναι πιο κατάλληλο για το σκοπό αυτό. Χρησιμοποιείται συχνότερα για την εκτέλεση εντολών DDL ή για την εκτέλεση μιας αποθηκευμένης διαδικασίας (παρόλο που πρέπει να χρησιμοποιήσετε τοTADOStoredProc για τέτοιες εργασίες) που δεν επιστρέφει ένα σύνολο αποτελεσμάτων.
Το SQL που χρησιμοποιείται σε ένα στοιχείο ADOQuery πρέπει να είναι αποδεκτό από το πρόγραμμα οδήγησης ADO που χρησιμοποιείται. Με άλλα λόγια, θα πρέπει να είστε εξοικειωμένοι με τις διαφορές γραφής SQL μεταξύ, για παράδειγμα, MS Access και MS SQL.
Όπως όταν εργάζεστε με το στοιχείο ADOTable, τα δεδομένα σε μια βάση δεδομένων είναι προσβάσιμα χρησιμοποιώντας μια σύνδεση αποθήκευσης δεδομένων που δημιουργήθηκε από το στοιχείο ADOQuery χρησιμοποιώντας τοΣύνδεση ιδιότητα ή μέσω ξεχωριστού στοιχείου ADOConnection που καθορίζεται στο Σύνδεσηιδιοκτησία.
Για να δημιουργήσετε μια φόρμα Delphi ικανή να ανακτήσει τα δεδομένα από μια βάση δεδομένων της Access με το στοιχείο ADOQuery απλώς αποθέστε όλα τα σχετικά στοιχεία πρόσβασης σε δεδομένα και συνειδητοποίησης δεδομένων σε αυτό και δημιουργήστε έναν σύνδεσμο όπως περιγράφεται στα προηγούμενα κεφάλαια αυτού σειρά μαθημάτων. Τα στοιχεία πρόσβασης δεδομένων: DataSource, ADOConnection μαζί με το ADOQuery (αντί του ADOTable) και ένα στοιχείο γνώσης δεδομένων όπως το DBGrid είναι το μόνο που χρειαζόμαστε.
Όπως εξηγήθηκε ήδη, χρησιμοποιώντας το Object Inspector ορίστε τη σύνδεση μεταξύ αυτών των στοιχείων ως εξής:
DBGrid1.DataSource = DataSource1
DataSource1.DataSet = ADOQuery1
ADOQuery1.Connection = ADOConnection1
// δημιουργήστε το ConnectionString
ADOConnection1.ConnectionString = ...
ADOConnection1.LoginPrompt = False
Εκτέλεση ερωτήματος SQL
Το στοιχείο TADOQuery δεν έχει Όνομα πίνακαιδιοκτησία όπως το TADOTable. Το TADOQuery ονομάζεται μια ιδιότητα (TStrings) SQL που χρησιμοποιείται για την αποθήκευση της δήλωσης SQL. Μπορείτε να ορίσετε την τιμή της ιδιότητας SQL με το Object Inspector κατά το σχεδιασμό ή μέσω κώδικα κατά το χρόνο εκτέλεσης.
Κατά την ώρα του σχεδιασμού, καλέστε τον επεξεργαστή ιδιοτήτων για την ιδιότητα SQL κάνοντας κλικ στο κουμπί έλλειψης στο Object Inspector. Πληκτρολογήστε την ακόλουθη δήλωση SQL: "SELECT * FROM Authors".
Η δήλωση SQL μπορεί να εκτελεστεί με έναν από τους δύο τρόπους, ανάλογα με τον τύπο της δήλωσης. Οι δηλώσεις γλώσσας ορισμού δεδομένων εκτελούνται γενικά με το ExecSQL μέθοδος. Για παράδειγμα, για να διαγράψετε μια συγκεκριμένη εγγραφή από έναν συγκεκριμένο πίνακα, θα μπορούσατε να γράψετε μια δήλωση DELETE DDL και να εκτελέσετε το ερώτημα με τη μέθοδο ExecSQL.
Οι (συνηθισμένες) δηλώσεις SQL εκτελούνται με τη ρύθμιση του TADOQuery. Ενεργός ιδιοκτησία προς Αληθής ή καλώντας τοΑνοιξε μέθοδος (ουσιαστικά το ίδιο). Αυτή η προσέγγιση είναι παρόμοια με την ανάκτηση δεδομένων πίνακα με το στοιχείο TADOTable.
Κατά το χρόνο εκτέλεσης, η δήλωση SQL στην ιδιότητα SQL μπορεί να χρησιμοποιηθεί ως οποιοδήποτε αντικείμενο StringList:
με το ADOQuery1 ξεκινάτε Κλείσιμο.
SQL.Clear;
SQL.Add: = 'SELECT * FROM Authors' SQL.Add: = 'ORDER BY authorname DESC' Άνοιγμα;
τέλος;
Ο παραπάνω κώδικας, κατά το χρόνο εκτέλεσης, κλείνει το σύνολο δεδομένων, αδειάζει τη συμβολοσειρά SQL στην ιδιότητα SQL, εκχωρεί μια νέα εντολή SQL και ενεργοποιεί το σύνολο δεδομένων καλώντας τη μέθοδο Open.
Σημειώστε ότι προφανώς η δημιουργία μόνιμης λίστας αντικειμένων πεδίου για ένα στοιχείο ADOQuery δεν έχει νόημα. Την επόμενη φορά που θα καλέσετε τη μέθοδο Open, το SQL μπορεί να είναι τόσο διαφορετικό ώστε να αλλάξει ολόκληρο το σύνολο των αρχειοθετημένων ονομάτων (και τύπων). Φυσικά, αυτό δεν συμβαίνει εάν χρησιμοποιούμε το ADOQuery για να πάρουμε τις σειρές από έναν μόνο πίνακα με το σταθερό σύνολο πεδίων - και το σύνολο που προκύπτει εξαρτάται από το μέρος ΠΟΥ από τη δήλωση SQL.
Δυναμικά ερωτήματα
Μία από τις εξαιρετικές ιδιότητες των στοιχείων TADOQuery είναι το Παραμάς ιδιοκτησία. Ένα παραμετροποιημένο ερώτημα είναι αυτό που επιτρέπει ευέλικτη επιλογή γραμμής / στήλης χρησιμοποιώντας μια παράμετρο στον όρο WHERE μιας δήλωσης SQL. Η ιδιότητα Params επιτρέπει αντικαταστάσιμες παραμέτρους στην προκαθορισμένη δήλωση SQL. Μια παράμετρος είναι ένα σύμβολο κράτησης θέσης για μια τιμή στον όρο WHERE, που ορίστηκε λίγο πριν από το άνοιγμα του ερωτήματος. Για να καθορίσετε μια παράμετρο σε ένα ερώτημα, χρησιμοποιήστε μια άνω και κάτω τελεία (:) που προηγείται ενός ονόματος παραμέτρου.
Κατά το σχεδιασμό-ώρα χρησιμοποιήστε το Object Inspector για να ορίσετε την ιδιότητα SQL ως εξής:
ADOQuery1.SQL: = 'SELECT * FROM Applications WHERE type =: apptype'
Όταν κλείσετε το παράθυρο του προγράμματος επεξεργασίας SQL, ανοίξτε το παράθυρο Παράμετροι κάνοντας κλικ στο κουμπί έλλειψης στο Object Inspector.
Η παράμετρος στην προηγούμενη δήλωση SQL ονομάζεταιτύπος. Μπορούμε να ορίσουμε τις τιμές των παραμέτρων στη συλλογή Params κατά το χρόνο σχεδίασης μέσω του παραθύρου διαλόγου Parameters, αλλά τις περισσότερες φορές θα αλλάζουμε τις παραμέτρους κατά το χρόνο εκτέλεσης. Ο διάλογος παραμέτρων μπορεί να χρησιμοποιηθεί για τον καθορισμό των τύπων δεδομένων και των προεπιλεγμένων τιμών των παραμέτρων που χρησιμοποιούνται σε ένα ερώτημα.
Κατά το χρόνο εκτέλεσης, οι παράμετροι μπορούν να αλλάξουν και το ερώτημα να εκτελεστεί ξανά για να ανανεώσετε τα δεδομένα. Για να εκτελέσετε ένα παραμετροποιημένο ερώτημα, είναι απαραίτητο να παρέχετε μια τιμή για κάθε παράμετρο πριν από την εκτέλεση του ερωτήματος. Για να τροποποιήσουμε την τιμή της παραμέτρου, χρησιμοποιούμε την ιδιότητα Params ή τη μέθοδο ParamByName. Για παράδειγμα, δεδομένης της δήλωσης SQL όπως παραπάνω, στο χρόνο εκτέλεσης θα μπορούσαμε να χρησιμοποιήσουμε τον ακόλουθο κώδικα:
με το ADOQuery1 ξεκινούν
Κλείσε;
SQL.Clear;
SQL.Add ('SELECT * FROM Applications WHERE type =: apptype');
ParamByName ('apptype'). Τιμή: = 'πολυμέσα';
Ανοιξε;
τέλος;
Όπως και όταν εργάζεστε με το στοιχείο ADOTable, το ADOQuery επιστρέφει ένα σύνολο ή εγγραφές από έναν πίνακα (ή δύο ή περισσότερα). Η πλοήγηση σε ένα σύνολο δεδομένων γίνεται με το ίδιο σύνολο μεθόδων όπως περιγράφεται στο κεφάλαιο "Πίσω από δεδομένα σε σύνολα δεδομένων".
Πλοήγηση και επεξεργασία του ερωτήματος
Σε γενικές γραμμές, το στοιχείο ADOQuery δεν πρέπει να χρησιμοποιείται όταν πραγματοποιείται επεξεργασία. Τα ερωτήματα που βασίζονται σε SQL χρησιμοποιούνται κυρίως για σκοπούς αναφοράς. Εάν το ερώτημά σας επιστρέφει ένα σύνολο αποτελεσμάτων, μερικές φορές είναι δυνατό να επεξεργαστείτε το σύνολο δεδομένων που επιστράφηκε. Το σύνολο αποτελεσμάτων πρέπει να περιέχει εγγραφές από έναν μόνο πίνακα και δεν πρέπει να χρησιμοποιεί συναρτήσεις SQL. Η επεξεργασία ενός συνόλου δεδομένων που επιστρέφεται από το ADOQuery είναι η ίδια με την επεξεργασία του συνόλου δεδομένων του ADOTAble.
Παράδειγμα
Για να δείτε κάποια ενέργεια ADOQuery θα κωδικοποιήσουμε ένα μικρό παράδειγμα. Ας κάνουμε ένα ερώτημα που μπορεί να χρησιμοποιηθεί για τη λήψη σειρών από διάφορους πίνακες σε μια βάση δεδομένων. Για να δείξουμε τη λίστα όλων των πινάκων σε μια βάση δεδομένων μπορούμε να χρησιμοποιήσουμε το GetTableNamesμέθοδος του ADOConnection συστατικό. Τα GetTableNames στο συμβάν OnCreate της φόρμας συμπληρώνει το ComboBox με τα ονόματα των πινάκων και το κουμπί χρησιμοποιείται για το κλείσιμο του ερωτήματος και για την αναδημιουργία του για την ανάκτηση των εγγραφών από έναν επιλεγμένο πίνακα. Οι διαχειριστές συμβάντων () θα πρέπει να μοιάζουν με:
διαδικασία TForm1.FormCreate (Αποστολέας: TObject);
να αρχίσει
ADOConnection1.GetTableNames (ComboBox1 Items);
τέλος;
διαδικασία TForm1.Button1Click (Αποστολέας: TObject);
var tblname: συμβολοσειρά;
να αρχίσει
εάν ComboBox1.IemIndex τότε Έξοδος;
tblname: = ComboBox1 Items [ComboBox1.IemIndex];
με το ADOQuery1 ξεκινούν
Κλείσε;
SQL.Text: = 'SELECT * FROM' + tblname;
Ανοιξε;
τέλος;
τέλος;
Σημειώστε ότι όλα αυτά μπορούν να γίνουν χρησιμοποιώντας την ιδιότητα ADOTable και το TableName.