• GBase8s数据库FOR UPDATE 子句


    当您打算更新由准备好的 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 游标再次存取。

  • 相关阅读:
    【FPGA图像融合】基于vivado HLS的图像融合算法的FPGA实现
    独立站品牌出海盛行,大批卖家转型逐利
    ICC2分析时序的神器 analyze_design_violations
    http客户端Feign
    ASCII码与字符对照表(附转换代码)
    大数据组件spark hadoop hive简单介绍
    网络结构模式,协议,端口,网络模型,arp
    json、pikcle序列化模块
    MDK(Keil)的MAP文件都记录了啥
    盘点常见的动态内存的错误
  • 原文地址:https://blog.csdn.net/weixin_48486849/article/details/125413996