mco_db_extend_t
接口适用于实时数据库 RT 。
在事务中扩展数据库内存。
此函数可扩展数据库使用的内存量。请注意,mco_db_extend()
必须在任何事务之外调用,而 mco_db_extend_t()
则必须在 READ_WRITE
事务中调用。通常在数据库写入操作因内存不足而失败时使用。
MCO_RET mco_db_extend_t(
/*IN*/ mco_trans_h t,
/*IN*/ void * mem,
/*IN*/ uint4 size
);
参数
t
mco_trans_h
当前事务句柄。
mem
void *
内存块的起始地址。
size
uint4
内存块的大小 (以字节为单位)。
返回
MCO_S_OK
已成功扩展数据库内存。
MCO_E_NOINSTANCE
指定的数据库未打开。
MCO_ERR_TRN
发生数据库事务错误。(例如。数据库已经被具有打开事务的其他线程打开.)。
MCO_E_ILLEGAL_PARAM
如果设备大小过小则返回。最小大小取决于运行时配置和硬件架构。在 x64 平台上且配置为 100 个连接(默认值)时,最小大小略超过 1K(1104 字节)。
示例
const char * dbname = "SimpleDb";
int main(int argc, char* argv[])
{
mco_db_h db;
MCO_RET rc;
char *mem = malloc( DBSIZE );
if( (rc = mco_runtime_start()) != MCO_S_OK)
exit(-1);
rc = mco_db_open( dbname, simpledb_get_dictionary(), mem, DBSIZE, (uint2)PAGESIZE );
...
rc = mco_db_connect(dbname, &db);
...
/* 检测到内存不足的情况 */
mco_db_free_pages(db, &freepages);
mco_db_total_pages(db, &totalpages );
if(freepages < totalpages / 10)
{
// 扩展数据库
char * mem2 = malloc(SECOND_SEGSZ);
if( mem2 )
{
rc = mco_trans_start(db, MCO_READ_WRITE, MCO_TRANS_FOREGROUND, &t);
rc = mco_db_extend_t(t, mem2, SECOND_SEGSZ);
if ( MCO_S_OK != rc )
mco_trans_rollback();
else
mco_trans_commit();
...
}
}
}
文件
- 头文件:
mco.h
- 源文件:
mcodb.c
- 库:
libmcolib.a