• 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 游标再次存取。

  • 相关阅读:
    实现端口扫描
    Java设计模式—享元(FlyWeight)模式
    使用MVS-GaN HEMT紧凑模型促进基于GaN的射频和高电压电路设计
    层次聚类分析及代码实现
    打造无证服务化:这个政务服务平台有点不一样
    java毕业设计eonvan数字工坊网站mybatis+源码+调试部署+系统+数据库+lw
    PADS画2.54mm排针
    微信小程序echart导出图片
    OPTEE:TA命令操作的实现(三)
    动手学深度学习_全卷积网络 FCN
  • 原文地址:https://blog.csdn.net/weixin_48486849/article/details/125413996