/**
* 素材检索
* 填冲好一个输入结构, 作为函数的参数进行调用.
*
* 这个输入结构中的各各成员项可以为空,
* 通过判断来确定数据库检索条件, 即: 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;
}