Sqlite3内存不断增加的问题

在嵌入式环境下集成 sqlite3 数据库,但是在插入数据时,发现内存不断增加的问题,调试到最后发现是执行 sqlite3_exec() 函数引起的,注释该函数就不会导致内存增加,请问这个要怎么处理呢?

代码如下:

int ExecDBSQL(sqlite3 *pSqliteDb, char *pSqlBuf)
{
    int ret = 0;
    char *pErrmsg = NULL;

    if ((NULL == pSqlBuf) || (strlen(pSqlBuf) < 5))
    {
        printf("pSqlBuf is null\n");
        return -1;
    }

    ret = sqlite3_exec(pSqliteDb, pSqlBuf, NULL, NULL, &pErrmsg);
    if (DB_OK != ret)
    {
        printf("sqlite3 exec error, ret: %d, errmsg: %s\n", ret, pErrmsg);
    }
    sqlite3_free(pErrmsg);

    return ret;
}

你不断插入,内存就不断增加;
同样
你不断删除,内存就不断减少。
(^_^)