在嵌入式环境下集成 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;
}