• 1.ODBC连接Postgresql


    SQLDriverConnect

    SQLDriverConnect 是 SQLConnect 的替代方法。 它支持需要比 SQLConnect 中的三个参数更多的连接信息的数据源、对话框来提示用户输入所有连接信息,以及系统信息中未定义的数据源。

    方法1:通过对话框输入所有连接信息:
    #include   
    #include   
    #include 
    
    int main() {
        SQLHENV henv;
        SQLHDBC hdbc;
        SQLHSTMT hstmt;
        SQLRETURN retcode;
    
        SQLCHAR OutConnStr[255];
        SQLSMALLINT OutConnStrLen;
    
        HWND desktopHandle = GetDesktopWindow();   // desktop's window handle  
    
        // Allocate environment handle  
        retcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);
    
        // Set the ODBC version environment attribute  
        if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
            retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER*)SQL_OV_ODBC3, 0);
    
            // Allocate connection handle  
            if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);
    
                // Set login timeout to 5 seconds  
                if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                    SQLSetConnectAttr(hdbc, SQL_LOGIN_TIMEOUT, (SQLPOINTER)5, 0);
    
                    retcode = SQLDriverConnect( // SQL_NULL_HDBC  
                        hdbc,
                        desktopHandle,
                        (SQLCHAR*)"driver={PostgreSQL ODBC Driver(UNICODE)}",
                        _countof("driver={PostgreSQL ODBC Driver(UNICODE)}"),
                        OutConnStr,
                        255,
                        &OutConnStrLen,
                        SQL_DRIVER_PROMPT);
    
                    // Allocate statement handle  
                    if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                        retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);
    
                        // Process data  
                        if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                            SQLFreeHandle(SQL_HANDLE_STMT, hstmt);
                            std::cout << "connect successed!" << std::endl;
                        }
    
                        SQLDisconnect(hdbc);
                    }
    
                    SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
                }
            }
            SQLFreeHandle(SQL_HANDLE_ENV, henv);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    方法2:指定所有连接信息连接数据库
    #include   
    #include   
    #include 
    
    int main() {
        SQLHENV henv;
        SQLHDBC hdbc;
        SQLHSTMT hstmt;
        SQLRETURN retcode;
    
        SQLCHAR OutConnStr[255];
        SQLSMALLINT OutConnStrLen;
    
        HWND desktopHandle = GetDesktopWindow();   // desktop's window handle  
    
        // Allocate environment handle  
        retcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);
    
        // Set the ODBC version environment attribute  
        if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
            retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER*)SQL_OV_ODBC3, 0);
    
            // Allocate connection handle  
            if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);
    
                // Set login timeout to 5 seconds  
                if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                    SQLSetConnectAttr(hdbc, SQL_LOGIN_TIMEOUT, (SQLPOINTER)5, 0);
    
                    retcode = SQLDriverConnect( // SQL_NULL_HDBC  
                        hdbc,
                        NULL,
                        (SQLCHAR*)"Driver={PostgreSQL ODBC Driver(UNICODE)};Server=192.168.8.102;Port=5432;Database=postgres;UID=postgres;PWD=postgres",
                        SQL_NTS,
                        OutConnStr,
                        255,
                        &OutConnStrLen,
                        SQL_DRIVER_NOPROMPT);
    
                    // Allocate statement handle  
                    if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                        retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);
    
                        // Process data  
                        if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {
                            SQLFreeHandle(SQL_HANDLE_STMT, hstmt);
                            std::cout << "connect successed!" << std::endl;
                        }
    
                        SQLDisconnect(hdbc);
                    }
    
                    SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
                }
            }
            SQLFreeHandle(SQL_HANDLE_ENV, henv);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
  • 相关阅读:
    React Hooks useState 使用详解+实现原理+源码分析
    GitHub【入门】从入门到会用(千字总结●超详细)
    深入浅出PyTorch——主要模块和基础实战
    动态顺序表的增删查改(C语言实现)
    讲讲我是如何一步步成为CSDN博客专家的心路历程
    ESP32智能小车+PS2无线遥控器+麦克纳姆轮+microPython
    Vue3.0安装与构建项目
    微信小程序 —— 会议OA项目首页布局与Mock数据交互
    【Spring进阶系列丨第一篇】初识Spring开发
    简述什么是值传递和引用传递?
  • 原文地址:https://blog.csdn.net/qq_28368377/article/details/126336654