华为云云数据库GaussDB管理连接_云淘科技

嵌入式SQL程序中的SQL语句默认是在当前连接(也就是最近打开的那一个)上执行。如果一个应用需要管理多个连接,那么有以下两种方法。

方法1:为每个SQL语句明确选择一个连接:

EXEC SQL AT connection-name SELECT ...;

适合于应用程序需以混合顺序使用多个连接的情况。

如果应用程序创建多个执行线程,它们不能共享同一个连接,必须明确控制对连接的访问(利用互斥量)或者每个线程使用一个唯一连接。

方法2:执行一个语句来切换连接:

EXEC SQL SET CONNECTION connection-name;

适用于许多语句在同一个连接上执行的情况。

管理连接示例如下:

#include   
EXEC SQL BEGIN DECLARE SECTION;
    char dbname[1024]; 
EXEC SQL END DECLARE SECTION;  

int main() 
{
     EXEC SQL CONNECT TO testdb1 AS con1 USER testuser;
     EXEC SQL CONNECT TO testdb2 AS con2 USER testuser;
     EXEC SQL CONNECT TO testdb3 AS con3 USER testuser;

     /* 这个查询将在最近打开的数据库 "testdb3" 中执行 */
     EXEC SQL SELECT current_database() INTO :dbname;
     printf("current=%s (should be testdb3)
", dbname);

     /* 使用 "AT" 在 "testdb2" 中运行一个查询 */
     EXEC SQL AT con2 SELECT current_database() INTO :dbname;
     printf("current=%s (should be testdb2)
", dbname);

     /* 切换当前连接到 "testdb1" */
     EXEC SQL SET CONNECTION con1;

     EXEC SQL SELECT current_database() INTO :dbname;
     printf("current=%s (should be testdb1)
", dbname);

     EXEC SQL DISCONNECT ALL;
     return 0; 
}

示例输出:

current=testdb3 (should be testdb3)
current=testdb2 (should be testdb2) 
current=testdb1 (should be testdb1)

多线程模式下不支持不同线程使用同一连接名,每个线程连接名唯一。
连接的建立和关闭需要在同一进程或线程进行。

父主题: 管理数据库连接

同意关联代理商云淘科技,购买华为云产品更优惠(QQ 78315851)

内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家