关于使用MongoDB的C驱动,分片存储数据的问题
使用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,所以我想使用分片的方式存储数据。
请问怎么实现啊?