esql中声明变量和使用动态游标

  1. 在esql中使用的变量声明
    这些变量在使用时前面要加上: 
    1. exec sql begin declare section;
    2.  char _id[10];
    3.  char _name[20];
    4.  char _password[18];
    5.  char _branchid[9];
    6.  char _roleid[2];
    7.  char db_name[128+1];
    8.  char _sql[] = "update userinfo set password=? where userid=?";
    9. exec sql end declare section;
  2. 简单的esql操作
    动态SQL操作例1
    1. EXEC SQL DECLARE cursor1 CURSOR FOR /
    2.   select userid from userinfo;
    3.   EXEC SQL OPEN cursor1;
    4.   do
    5.   {
    6.     EXEC SQL FETCH cursor1 INTO :_id;
    7.     if(sqlca.sqlcode == 100) break;
    8.     printf("%10s/n", _id);
    9.   } while(1);
     
    动态SQL操作例2    

    1. exec sql begin declare section; 
    2. char _id[10];
    3. char _name[20];
    4. char _password[18];
    5. char _sql[] = "update userinfo set password=? where userid=?";
    6. exec sql end declare section;
    7. memset(_id, 0x00, sizeof(_id));
    8. memset(_password, 0x00, sizeof(_password));
    9. sprintf(_id, "%s""001");
    10. sprintf(_password, "%s""haha");
    11. EXEC SQL PREPARE prep_stat FROM :_sql;
    12. EXEC SQL EXECUTE prep_stat USING :_password, :_id;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值