Guidelines for Creating Unique and Sequential Keys (136921)
The information in this article applies to:
- Microsoft Visual FoxPro for Windows 3.0
This article was previously published under Q136921 SUMMARY
You can create unique and sequential keys in Visual FoxPro by using two
of Visual FoxPro's new features: Stored Procedures and Default Values.
MORE INFORMATION
To see an example showing how to create unique and sequential keys, please
look at the TasTrade sample application located in the Vfp\Samples\Mainsamp
directory. In this sample, the NewID() stored procedure has been written
and stored in the TasTrade database. The following text is taken from the
"Behind the Scenes" feature of the Tastrade sample:
The NewID() stored procedure creates unique IDs in the system. It returns
the default value for the primary keys for the Supplier, Products,
Employee, Category, Shippers, and Orders tables.
Code in NewID() opens Setup.dbf, looks for table alias in the Key_name
field, reads the current value of the Value field, increments it by 1, and
then writes it back to Setup.dbf. The value that was read from the Value
field before incrementing is then returned as the primary key value for a
record.
Note that the NewID() stored procedure is also designed to accept an alias
as a parameter. The same technique could then be used to maintain
incrementing values that were not being used as primary keys. An example of
this is the order_number record, which is used to generate order numbers
for the Orders table.
You can modify stored procedures by first opening the database with the
OPEN DATABASE command, and then using the MODIFY PROCEDURES command to
bring up an editing window. Alternatively, you can use the MODIFY DATABASE
command, and then click the Stored Procedures button on the toolbar.
The code for NewID() is as follows:
FUNCTION NewID(tcAlias)
LOCAL lcAlias, ;
lcID, ;
lcOldReprocess, ;
lnOldArea
lnOldArea = SELECT()
IF PARAMETERS() < 1
lcAlias = UPPER(ALIAS())
ELSE
lcAlias = UPPER(tcAlias)
ENDIF
lcID = ""
lcOldReprocess = SET('REPROCESS')
*-- Lock until user presses Esc
SET REPROCESS TO AUTOMATIC
IF !USED("SETUP")
USE tastrade!setup IN 0
ENDIF
SELECT setup
IF SEEK(lcAlias, "setup", "key_name")
IF RLOCK()
lcID = setup.value
REPLACE setup.value WITH ;
STR(VAL(ALLT(lcID)) + 1, LEN(setup.value))
UNLOCK
ENDIF
ENDIF
SELECT (lnOldArea)
SET REPROCESS TO lcOldReprocess
RETURN lcID
ENDFUNC
Modification Type: | Major | Last Reviewed: | 8/20/1999 |
---|
Keywords: | KB136921 |
---|
|