多个线程可以在 Monetdbe 中各自打开自己的数据库连接吗

问题描述

我将 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,您应该可以继续使用。