Go Premium for a chance to win a PS4. Enter to Win

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 458
  • Last Modified:

Locate Function

How - and this is frustrating the  HELL out of me - do you use LOCATE???  I have numerous books and examples and NONE of them explain how to search for multiple strings contained in multiple keywords.

According to the book, locate can search more than one keyfield using more than one keyvalue.  How??

Any help - or even better - sample would be appreciated.

Thanks heaps!
0
Stuart_Johnson
Asked:
Stuart_Johnson
1 Solution
 
Stuart_JohnsonAuthor Commented:
Edited text of question
0
 
ozzyCommented:
From the delphi 2.0 help:
The Locate method locates and moves to the first record matching the supplied search criteria. KeyFields lists the field or fields you want to search; to search more than one, separate each field name with a semicolon. KeyValues is a variant specifying the field value to match, or an array of field values, if KeyFields lists more than one field. Options lets you specify case-insensitive or partial-key matching.
Locate uses the fastest possible method to locate a matching record; if the dataset has an index on the specified fields that's compatible with case-insensitive matching (if you specify that in Options), the index will be used. Otherwise, Locate sets up a Borland Database Engine filter for efficient searching.

Locate returns True if a matching record could be found or False if no matches were found.

The following code moves the cursor to the first row in the CustTable where the value in the Company column is "Professional Divers, Ltd.":

var
  LocateSuccess: Boolean;
  SearchOptions: TLocateOptions;
begin
  SearchOptions := [loPartialKey];
  LocateSuccess := CustTable.Locate('Company', 'Professional Divers, Ltd.',
    SearchOptions);
end;

If Locate finds a match, the first record containing the match becomes the current record. Locate returns True if it finds a matching record, False if it does not. If a search fails, the current record does not change.

This seems pretty straightforward about how to use multiple keyfileds.  Just seperate them by semicolons.  To search for more than one string, you may have to do multiple searches.

Hope this helps.  I know you could have looked this up, so if you have, don't flame me.  :-)

0

Featured Post

Vote for the Most Valuable Expert

It’s time to recognize experts that go above and beyond with helpful solutions and engagement on site. Choose from the top experts in the Hall of Fame or on the right rail of your favorite topic page. Look for the blue “Nominate” button on their profile to vote.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now