PRB: Record Pointer Moves to EOF After INSERT - SQL FailsID: Q130083 3.00 WINDOWS
The information in this article applies to:
SYMPTOMSThe record pointer moves to the End of File marker (EOF) instead of remaining on the current record after an INSERT - SQL command fails.
CAUSEThe INSERT - SQL command failed because a field or row level validation rule was violated.
WORKAROUNDTo work around this behavior, run the following code to initialize a variable to store the record pointer position before the INSERT. If the INSERT fails, the variable can be used to restore the record pointer to its previous position using the ON ERROR routine. Create a new program named Ins_Trap: ***Begin Program Ins_Trap*** ON ERROR DO error_hand WITH ERROR() && When an error occurs the error_hand CLOSE ALL
* The following command adds a table with a row level rule:
*
CREATE TABLE ins_tbl (cfname C(20), clname C(20), CHECK cfname <> clname)
*
* The following two lines of code populate the empty table.
*
DO Insert_Proc WITH "FirstName","LastName"
DO Insert_Proc WITH "Another", "Name"
*
* The next line causes the validation rule to fail:
*
DO Insert_Proc WITH "Name", "Name"
ON ERROR
WAIT WINDOW 'Done'
PROCEDURE Insert_Proc ENDPROC
PROCEDURE error_hand ENDPROC
*** End Program Ins_Trap ***
Save and execute the INS_TRAP.PRG program.
STATUSThis behavior is by design.
MORE INFORMATION
Steps to Reproduce BehaviorIn the Command window, type the following commands:
CREATE TABLE ins_tbl (cfname C(20), clname C(20), CHECK cfname <> clname)
INSERT INTO ins_tbl VALUES("John", "Doe") INSERT INTO ins_tbl VALUES("Doe", "Doe") When the last INSERT INTO command fails, the record pointer is positioned at EOF (End of File). Additional reference words: 3.00 VFoxWin KBCategory: kbprb KBSubcategory: FxprgTable
|
Last Reviewed: May 22, 1998 © 2000 Microsoft Corporation. All rights reserved. Terms of Use. |