问题描述
我将 monetdbe 嵌入到多线程 C++ 应用程序中。
我的应用程序的服务器端有多个线程运行,每个线程打开自己的同一个 monetdb 数据库实例,即每个线程运行以下代码:
monetdbe_database db = NULL;
if (monetdbe_open(&db,url /* inmemory database */,NULL /* no options */)) {
fprintf(stderr,"Failed to open database\n");
return -1;
}
每个线程运行由连接到服务器的客户端发送的 monetdb 查询。因此,可以有多个客户端同时连接到数据库,并且它们可能会同时发送访问/更新相同底层表的请求。 我只是想确保 monetdb 是为处理这种情况而设计的。
我知道 monetdb 不是设计为高事务数据库,我的用例更具分析性,但我确实有几个客户端将连接到服务器,有时它们可能会针对相同的数据库表运行查询同时。这是使用 monetdbe 运行多线程应用程序的正确方法吗?
解决方法
根据github上的这个问题(https://github.com/MonetDBSolutions/monetdbe-examples/issues/11)和这个例子(https://github.com/MonetDBSolutions/monetdbe-examples/blob/master/C/concurrent.c)。
只要您没有为每个连接使用相同的 monetdbe_database
,您应该可以继续使用。