动态Sql的例子

/**
 * 素材检索
 * 填冲好一个输入结构, 作为函数的参数进行调用.
 *
 * 这个输入结构中的各各成员项可以为空, 
 * 通过判断来确定数据库检索条件, 即: SELECT语句后面的条件.
 *
 */
void MatSearch(struct GrpMember *in)
{
    /* 定义临时变量 */
    char buf[256]; /* buffer */

    /* 定义宿主变量 */
    EXEC SQL BEGIN DECLARE SECTION;
        char sql_buf[1024]; /* 存放SQL语句 */
        struct GrpMember ret; /* 查询结果 */
    EXEC SQL END DECLARE SECTION;

    /** 
     * 根据参数, 构造SQL语句
     *
     * 1 把SQL语句的前半部分拷贝到buffer中.
     * 2 判断输入参数的结构中各成员项是否为空, 如不为空, 则add到buffer中.
     */
    strcpy(sql_buf, "SELECT * FROM TBL_GRPMEMBER WHERE 1=1 ");
    if (!isEmpty(str_bgID))
    {
        sprintf(buf, "AND tbl_str_bgID = %s ", str_bgID);
        strcat(sql_buf, buf);
    }
    ...
    ...

    /* 准备动态SQL */
    EXEC SQL PREPARE sql_stmt FROM :sql_buf;

    /* 定义游标 */
    EXEC SQL DECLARE c1 CURSOR FOR sql_stmt;

    /* 打开游标: 执行查询 */
    EXEC SQL OPEN c1;

    /* 提取查询结果 */
    while(1)
    {
        EXEC SQL FETCH c1 INTO ret; /* 此处伪代码, 应该逐项INTO, 逗号分割, 具体见游标的使用 */
    }

    EXEC SQL CLOSE c1;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值