Cmakelist.txt之win-odbc-mysql

1.环境

1.1 下载

1.2 配置

2.cmakelist.txt

复制代码
cmake_minimum_required(VERSION 3.16)

project(ODBC LANGUAGES CXX)

set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

add_executable(ODBC main.cpp)

# include_directories可加
# 链接odbc32库
target_link_libraries(ODBC odbc32)


include(GNUInstallDirs)
install(TARGETS ODBC
    LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
    RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
)
复制代码

3.测试代码

复制代码
#include <windows.h>
#include <sql.h>
#include <sqlext.h>
#include <iostream>

int main() {
    SQLHENV henv;
    SQLHDBC hdbc;
    SQLHSTMT hstmt;
    SQLRETURN ret;

    // 分配环境句柄
    ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);
    if (ret!= SQL_SUCCESS && ret!= SQL_SUCCESS_WITH_INFO) {
        std::cerr << "SQLAllocHandle (ENV) failed" << std::endl;
        return 1;
    }

    // 设置环境属性
    ret = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0);
    if (ret!= SQL_SUCCESS && ret!= SQL_SUCCESS_WITH_INFO) {
        std::cerr << "SQLSetEnvAttr failed" << std::endl;
        SQLFreeHandle(SQL_HANDLE_ENV, henv);
        return 1;
    }

    // 分配连接句柄
    ret = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);
    if (ret!= SQL_SUCCESS && ret!= SQL_SUCCESS_WITH_INFO) {
        std::cerr << "SQLAllocHandle (DBC) failed" << std::endl;
        SQLFreeHandle(SQL_HANDLE_ENV, henv);
        return 1;
    }

    // 连接到数据库
    ret = SQLConnect(hdbc, (SQLCHAR*)"test_odbc_mysql", SQL_NTS, (SQLCHAR*)"root", SQL_NTS, (SQLCHAR*)"123456", SQL_NTS);
    if (ret!= SQL_SUCCESS && ret!= SQL_SUCCESS_WITH_INFO) {
        std::cerr << "SQLConnect failed" << std::endl;
        SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
        SQLFreeHandle(SQL_HANDLE_ENV, henv);
        return 1;
    }

    // 分配语句句柄
    ret = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);
    if (ret!= SQL_SUCCESS && ret!= SQL_SUCCESS_WITH_INFO) {
        std::cerr << "SQLAllocHandle (STMT) failed" << std::endl;
        SQLDisconnect(hdbc);
        SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
        SQLFreeHandle(SQL_HANDLE_ENV, henv);
        return 1;
    }

    // 执行查询语句
    ret = SQLExecDirect(hstmt, (SQLCHAR*)"SELECT * FROM tb_user", SQL_NTS);
    if (ret!= SQL_SUCCESS && ret!= SQL_SUCCESS_WITH_INFO) {
        std::cerr << "SQLExecDirect failed" << std::endl;
        SQLFreeHandle(SQL_HANDLE_STMT, hstmt);
        SQLDisconnect(hdbc);
        SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
        SQLFreeHandle(SQL_HANDLE_ENV, henv);
        return 1;
    }

    // 处理结果集(这里简单打印)
    SQLSMALLINT numCols;
    SQLNumResultCols(hstmt, &numCols);
    // 处理结果集--中文打印不了
    SQLCHAR buffer[1024];
    SQLLEN cbBuffer;
    while (SQLFetch(hstmt) == SQL_SUCCESS) {
        for (SQLSMALLINT i = 1; i <= numCols; i++) {
            SQLGetData(hstmt, i, SQL_C_CHAR, buffer, sizeof(buffer), &cbBuffer);
            std::cout << buffer << " ";
        }
        std::cout << std::endl;
    }
    // 释放语句句柄
    SQLFreeHandle(SQL_HANDLE_STMT, hstmt);
    // 断开连接
    SQLDisconnect(hdbc);
    // 释放连接句柄
    SQLFreeHandle(SQL_HANDLE_DBC, hdbc);
    // 释放环境句柄
    SQLFreeHandle(SQL_HANDLE_ENV, henv);

    return 0;
}

4.结果

相关推荐
胚芽鞘6811 小时前
关于java项目中maven的理解
java·数据库·maven
nbsaas-boot2 小时前
Java 正则表达式白皮书:语法详解、工程实践与常用表达式库
开发语言·python·mysql
sun0077004 小时前
mysql索引底层原理
数据库·mysql
程序员秘密基地4 小时前
基于html,css,vue,vscode,idea,,java,springboot,mysql数据库,在线旅游,景点管理系统
java·spring boot·mysql·spring·web3
workflower7 小时前
MDSE和敏捷开发相互矛盾之处:方法论本质的冲突
数据库·软件工程·敏捷流程·极限编程
叁沐7 小时前
MySQL 11 怎么给字符串字段加索引?
mysql
Tony小周7 小时前
实现一个点击输入框可以弹出的数字软键盘控件 qt 5.12
开发语言·数据库·qt
lifallen7 小时前
Paimon 原子提交实现
java·大数据·数据结构·数据库·后端·算法
TDengine (老段)8 小时前
TDengine 数据库建模最佳实践
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Elastic 中国社区官方博客8 小时前
Elasticsearch 字符串包含子字符串:高级查询技巧
大数据·数据库·elasticsearch·搜索引擎·全文检索·lucene