当您打算更新由准备好的 SELECT 语句返回的值,当存取这些值时,请在 ESQL/C 应用中和在
DB-Access 中使用 FOR UPDATE 子句。
准备包含 FRO UPDATE 子句的 SELECT 语句,等同于准备不带有 FOR UPDATE 子句的 SELECT 语
句,然后为准备好的语句声明 FOR UPDATE 游标。
FOR UPDATE 关键字通知数据库服务器可能会有更新,导致它使用比随同 Select 游标更严格的
锁。不带有此子句,您不可通过游标修改数据。您可指定哪些列可被更新。
在您为 SELECT . . . FOR UPDATE 语句声明游标之后,您可使用带有 WHERE CURRENT OF 子句的
UPDATE 或 DELETE 语句更新或删除当前选择了的行。关键字 CURRENT OF 引用最近存取了的行;
它们替代在 WHERE 子句中的通常的条件表达式。要以特定的值更新行,您的程序可能包含诸如下
列示例中的语句:
EXEC SQL BEGIN DECLARE SECTION;
char fname[ 16];
char lname[ 16];
EXEC SQL END DECLARE SECTION;
. . .
EXEC SQL connect to ‘stores_demo’;
/* select statement being prepared contains a for update clause */
EXEC SQL prepare x from ‘select fname, lname from customer for update’;
EXEC SQL declare xc cursor for x;
for (;😉
{
EXEC SQL fetch xc into $fname, $lname;
if (strncmp(SQLSTATE, ‘00’, 2) != 0) break;
printf(“%d %s %s\n”,cnum, fname, lname );
if (cnum == 999) --update rows with 999 customer_num
EXEC SQL update customer set fname = ‘rosey’ where current of xc;
}
EXEC SQL close xc;
EXEC SQL disconnect current;
SELECT . . . FOR UPDATE 语句,像 Update 游标一样,允许您执行那些单独使用 UPDATE 语句
不可能执行的更新,因为对更新的决定以及新的数据项的值都可基于该行的原始内容。UPDATE
语句不可查询正在被更新的表。
注: 在游标的 FETCH 循环内部的正常的更新不可确保在 UPDATE 之后再次存取更新了的行。
WHERE CURRENT OF 规范将 UPDATE 联系到 Update 游标,并确保每一行仅更新一次,通过在内部
保持一个已被更新了的行的列表。这些行将不被 Update 游标再次存取。