使用MongoDB的C驱动,将数据以分片(Gridfs)的方式存储到MongoDB数据库中? 5C

使用MongoDB的C驱动,怎样将一个字符串以分片(Gridfs)的方式存储到MongoDB数据库中?
我可以实现将一个文档以分片的方式存储到数据中,但是对于一个字符串就不会。
mongoc_init();
mongoc_database_t *database;

mongoc_collection_t *collection;

const char *uristr = "mongodb://111.111.111.111:27017/";
mongoc_client_t *client =mongoc_client_new(uristr);

database = mongoc_client_get_database (client, "dbTest");//获取数据库
collection = mongoc_client_get_collection (client, "dbTest",sTaskId.c_str());//获取指定数据库和集合

bson_error_t error;

bson_t *doc= bson_new();

BSON_APPEND_UTF8(doc, "filename", sFileName.c_str());
BSON_APPEND_UTF8(doc, "fileinfo", m_sFileInfo.c_str()); //m_sFileInfo是一个全局变量,内含一些其他的数据

bool r = mongoc_collection_insert(collection, MONGOC_INSERT_NONE, doc, NULL, &error);
if (!r)
{
bson_destroy(doc);
return false;
}
bson_destroy(doc);
这是我现在使用的方式,但是因为我将m_sFileinfo存储到了一个collection中,一个collection最大为16M,而我的m_sFileinfo超过了16M,所以我想使用分片的方式存储数据。
请问怎么实现啊?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!