MariaDB + Visual Studio 2017 环境下的 ODBC 入门开发
参考:
环境:
- Windows 10 x64 1803
- MariaDB TX 10.2.14 x64
- MariaDB ODBC Connector 3.0.3 x64
- Visual Studio 2017 Community 15.6.7
安装ODBC驱动并配置数据源:
先安装ODBC驱动。根据自身需求选择32或64位版本。我选择了64位版本。
打开ODBC数据源管理程序,点击右侧的“添加”按钮,添加用户DSN。如图操作。
后面按照默认配置,点击Next即可。
编写ODBC程序:
1 引入头文件:
#include <iostream> #include <windows.h> #include <sqlext.h>
2 定义一个检查错误的宏:
#define ODBC_CHECK(x) \ {\ if (!SQL_SUCCEEDED(x))\ {\ std::cout << "SQL error occurred at line " << __LINE__ << ".";\ getchar();\ exit(-);\ }\ }
3 ODBC初始化,为ODBC分配环境句柄
(分配环境句柄:注意,这里使用了新版的ODBC API SQLAllocHandle,而不是SQLAllocEnv)
// SQL Handle of ENVironment SQLHENV env; ODBC_CHECK(SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env)); // SQLAllocEnv ODBC_CHECK(SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, ));
4 建立应用程序与ODBC数据源的连接
(分配连接句柄:注意,这里使用了新版的ODBC API SQLAllocHandle,而不是SQLAllocConnect)
// SQL Handle of DB Connection SQLHDBC dbc; SQLCHAR dbcConfOut[]; ODBC_CHECK(SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc)); // SQLAllocConnect ODBC_CHECK(SQLSetConnectAttr(dbc, SQL_LOGIN_TIMEOUT, (SQLPOINTER), ));
(连接数据源:可以使用SQLConnect,也可以使用SQLDriverConnect;可以手动指定DSN名字,也可以通过弹出窗口来指定)
// specify manually ODBC_CHECK(SQLDriverConnect(dbc, NULL, (SQLCHAR *)"DSN=MariaDB;", SQL_NTS, dbcConfOut, sizeof(dbcConfOut), NULL, SQL_DRIVER_COMPLETE)); // SQLConnect // specify by popup window //ODBC_CHECK(SQLDriverConnect(dbc, GetDesktopWindow(), NULL, SQL_NTS, // dbcConfOut, sizeof(dbcConfOut), NULL, SQL_DRIVER_COMPLETE)); // SQLConnect
(显示连接成功的信息)
std::cout << "Connected!" << std::endl << "ConnStrIn = " << dbcConfOut << std::endl; SQLCHAR dbmsName[]; ODBC_CHECK(SQLGetInfo(dbc, SQL_DBMS_NAME, (SQLPOINTER)dbmsName, sizeof(dbmsName), NULL)); SQLCHAR dbmsVer[]; ODBC_CHECK(SQLGetInfo(dbc, SQL_DBMS_VER, (SQLPOINTER)dbmsVer, sizeof(dbmsVer), NULL)); std::cout << "DBMS Name = " << dbmsName << std::endl << "DBMS Version = " << dbmsVer << std::endl;
(分配语句句柄:注意,这里使用了新版的ODBC API SQLAllocHandle,而不是SQLAllocStmt)
// SQL Handle of STateMenT SQLHSTMT stmt; ODBC_CHECK(SQLAllocHandle(SQL_HANDLE_STMT, dbc, &stmt)); // SQLAllocStmt
5 利用SQLExecDirect语句,实现数据库应用程序对数据库的建立、查询、修改、删除等
(建立一个循环,一直接收并执行用户的SQL的语句,直到用户退出)
const int queryLen = ; SQLCHAR query[queryLen]; std::cout << "Please input your SQL query. Type CTRL+Z to quit." << std::endl << dbmsName << " >"; while (fgets((char*)query, queryLen - , stdin)) { if (query[] == '\n') { std::cout << dbmsName << " >"; continue; } switch (SQLExecDirect(stmt, query, SQL_NTS)) { case SQL_SUCCESS_WITH_INFO: case SQL_SUCCESS: { SQLSMALLINT col; SQLNumResultCols(stmt, &col); // SELECT if (col > ) { // 2 methods: SQLGetData() and SQLBindCol() // SQLGetData() is adopted here char buf[]; SQLUSMALLINT colidx; // print column names for (colidx = ; colidx <= col; ++colidx) { SQLColAttribute(stmt, colidx, SQL_DESC_NAME, buf, sizeof(buf), NULL, NULL); std::cout << buf << " "; } std::cout << std::endl; // iterate each row unsigned row = ; // row counter while (SQL_SUCCEEDED(SQLFetch(stmt))) { ++row; // iterate each column for (colidx = ; colidx <= col; ++colidx) { SQLLEN indicator; if (SQL_SUCCEEDED(SQLGetData(stmt, colidx, SQL_C_CHAR, buf, sizeof(buf), &indicator))) { if (indicator == SQL_NULL_DATA) strcpy(buf, "NULL"); std::cout << buf << " "; } } std::cout << std::endl; } if (row == ) { std::cout << "1 row in set." << std::endl; } else { std::cout << row << " rows in set." << std::endl; } } // CREATE, UPDATE, DELETE, etc. else { SQLLEN row; ODBC_CHECK(SQLRowCount(stmt, &row)); if (row == ) { std::cout << "1 row affected." << std::endl; } else { std::cout << row << " rows affected." << std::endl; } } break; } case SQL_ERROR: { std::cout << "Returned SQL_ERROR." << std::endl; break; } default: { std::cout << "Unknown SQLRETURN." << std::endl; } } ODBC_CHECK(SQLFreeStmt(stmt, SQL_CLOSE)); std::cout << dbmsName << " >"; }
6 检索查询结果集
7 结束数据库应用程序
// release resources ODBC_CHECK(SQLFreeHandle(SQL_HANDLE_STMT, stmt)); ODBC_CHECK(SQLDisconnect(dbc)); ODBC_CHECK(SQLFreeHandle(SQL_HANDLE_DBC, dbc)); ODBC_CHECK(SQLFreeHandle(SQL_HANDLE_ENV, env)); return ;
MariaDB + Visual Studio 2017 环境下的 ODBC 入门开发的更多相关文章
- (转)在SQL Server 2016,Visual Studio 2017环境下,连接数据库屡屡失败,在connectionString上出的问题
适用情景: 1,ServerVersion出了问题,“SqlCnt.ServerVersion”引发了类型“System.InvalidOperationException”的异常 2,在String ...
- 从头开始学eShopOnContainers——Visual Studio 2017环境配置
一.安装和配置Docker环境 1.安装Docker CE for Windows 从官方网站下载并安装,https://docs.docker.com/docker-for-windows/inst ...
- Visual Studio 2013环境下操作vc6/vc7/vc8等低版本平台项目【编译|生成|调试】
现代化的开发环境,微软一直在推出更新换代,我们所处的技术环境在日新月异的变化:不过在中国多数人们一边疲惫的追赶着时代的步伐,一边坚守着自己所获悉所掌握的那些紧吧吧的知本.对技术工具的掌握并非他们所想要 ...
- 基于visual studio 2017 以及cubemx 搭建stm32的开发环境(2)
主要解决 vs2017中,printf无法打印数据的问题. 在keil环境下正常使用printf功能,但是以下的重定向代码在vs2017下使用不了: #ifdef __GNUC__ /* With G ...
- 基于visual studio 2017 以及cubemx 搭建stm32的开发环境(0)
(1)安装visual studio 2017 官网下载安装即可 (2)安装visual GDB 链接:https://pan.baidu.com/s/1TgXI1BRQLAWiWlqCcIS9TA ...
- Visual Studio IDE环境下利用模板创建和手动配置CUDA项目教程
目前版本的cuda是很方便的,它的一个安装里面包括了Toolkit`SDK`document`Nsight等等,而不用你自己去挨个安装,这样也避免了版本的不同步问题. 1 cuda5.5的下载地址,官 ...
- Windows10 + Visual Studio 2017环境为C++工程安装使用ZMQ
因为需要用 C++ 实现联机对战的功能,但是不想直接用 winsock ,因此选了ZMQ 框架(不知道合不合适).安装的过程还是挺艰辛的.但是也学到了些东西,记录一下.另外,Zmq 的作者 Piete ...
- 基于visual studio 2017 以及cubemx 搭建stm32的开发环境(1)
参考如下文档: 传送门:http://www.stm32cube.com/article/128 如果链接不存在的话,下载我截屏好的图: 传送门:https://pan.baidu.com/s/1NC ...
- win10 visual studio 2017环境中安装CUDA8
从https://developer.nvidia.com/cuda-toolkit-archive下载CUDA 8 安装 从https://developer.nvidia.com/gamework ...
随机推荐
- rdb转为rdf
dump-rdf -f N-TRIPLE -b http://localhost:2020/ -o iswc.nt terrsearch.ttl
- Java搜索引擎选择: Elasticsearch与Solr(转)
Elasticsearch简介 Elasticsearch是一个实时的分布式搜索和分析引擎.它可以帮助你用前所未有的速度去处理大规模数据. 它可以用于全文搜索,结构化搜索以及分析,当然你也可以将这三者 ...
- jquery 获取浏览器窗口的可视区域高度 宽度 滚动条高
原文:http://www.open-open.com/code/view/1421827925437 alert($(window).height()); //可视区域高度 alert($(docu ...
- centos下开启htaccess
不知道原本 centOS是否默认支持 .htaccess 可能是因为我总弄配置文件无意中给搞坏了 今天要用到就查了下怎么开启 想要顺利开启需注意以下几点, 这几点都是在httpd.conf 这个配置文 ...
- 使用nginx转发不了静态文件
从django runserver的请求来看,都收不到静态文件请求, 查看firefox的web console请求,发现都是403 然后发现nginx不在当前用户组,并且当前用户的项目的读写权限是7 ...
- SolidEdge 工程图中如何快速将同一类元素放到同一个图层
在图层选项卡中新建一个尺寸线图层 点击聪慧选项(把它点凹下去),然后点击任意尺寸线,弹出聪慧选取选项,点击确定,则自动选择了所有尺寸线 点击移动图元,把刚才选中的所有尺寸线都移动到这个图层即可 ...
- gulp配置 - PC
初始化目录结构如下(图片看不清可以拖到桌面或者直接CTRL+鼠标滚轮进行观看) 开发环境示例: 上线环境示例: gulpfile.js(详解版) (2018-3-28)添加了scss处理(去除了les ...
- Java基础 笔记(四)
泛型: 泛型:通过<数据额类型>来接受一种引用数据类型.作用在编译时.使用检查 加入集合的对象是否属于该类型,从而把执行时的问题转换为编译时异常.提高程序的安全性 避免抛出 ClassCa ...
- ruby rails
http://www.zhihu.com/question/19552402 作者:陈振宇链接:http://www.zhihu.com/question/19552402/answer/1236 ...
- UI_Target/action 设计模式
RootView.m 中 UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem]; button.frame = CGRectM ...