基于ODBC开发
odbc接口环境部署好后,就可以开始进行开发了,微软官网有详细的接口操作说明,但odbc接口还是太底层,操作起来比较麻烦,这里采用数据库的封装类soci来实现快速开发。
soci是一个用C++封装的数据库访问库,通过“前端(应用程序)/核心/后端(数据库适配)”模式支持firebird,mysql,sqlite3,oracle,postgresql,odbc多种数据库
安装soci
git clone https://github.com/SOCI/soci.git
cd soci
mkdir build
cd build
cmake ..
make
sudo make install
注: 一般来说采用默认项就可以了,也可以为cmake附带一些参数:
1、设置自定义的安装目录: -DCMAKE_INSTALL_PREFIX=$HOME/local
2、指定自定义编译程序: -DCMAKE_C_COMPILER=gcc
3、如果你用的较高版本的编译器,默认是开启c++11的,如果cmake得到的SOCI_CXX11为OFF,你可以自行开启 -DSOCI_CXX11=ON, 否则后续使用时将会出现不一致的情况。
执行cmake 你会得到以下信息:
编码
这里有两种方案
1、使用dsn文件进行连接
2、指定连接字符串进行连接
soci是基于odbc进行封装的,具体连接相关信息可以参考SQLDriverConnect微软官方信息
方案一、使用dsn文件进行连接
创建dsn文件:myconn.dsn
[ODBC]
DRIVER=ODBC Driver 17 for SQL Server
UID=sa
PWD=123456
WSID=SOLARWIND
APP=SOCI Test Application
SERVER=127.0.0.1
DATABASE=mydatabase
Description=SQL on AppVeyor
代码:
#include <iostream>
#include <exception>
#include "soci/soci.h"
#include "soci/odbc/soci-odbc.h"
int main()
{
soci::backend_factory const &backEnd = *soci::factory_odbc();
try
{
soci::session sql(backEnd, "filedsn=./myconn.dsn");
soci::rowset<soci::row> rs = (sql.prepare << "select top 20 * FROM student");
for (auto it = rs.begin(); it != rs.end(); ++it)
{
const soci::row& row = *it;
std::cout << "id:" << row.get<int>(0)
<< " name:" << row.get<std::string>(1)
<< " motto:" << row.get<std::string>(2) << std::endl;
}
}
catch(soci::odbc_soci_error& e)
{
std::cout << e.what() << std::endl;
}
return 0;
}
编译:
c++ odbctest.cpp -o odbctest -lpthread -ldl -lodbc -lsoci_core -lsoci_odbc
方案二:使用连接字符串进行连接
#include <iostream>
#include <exception>
#include "soci/soci.h"
#include "soci/odbc/soci-odbc.h"
int main()
{
soci::backend_factory const &backEnd = *soci::factory_odbc();
try
{
soci::session sql(backEnd, "Driver={ODBC Driver 17 for SQL Server};server=127.0.0.1;database=mydatabase;uid=sa;pwd=123456;");
soci::rowset<soci::row> rs = (sql.prepare << "select top 20 * FROM student");
for (auto it = rs.begin(); it != rs.end(); ++it)
{
const soci::row& row = *it;
std::cout << "id:" << row.get<int>(0)
<< " name:" << row.get<std::string>(1)
<< " motto:" << row.get<std::string>(2) << std::endl;
}
}
catch(soci::odbc_soci_error& e)
{
std::cout << e.what() << std::endl;
}
return 0;
}
附不同数据库的odbc连接字符串:
access "Driver={microsoft access driver(*.mdb)};dbq=*.mdb;uid=admin;pwd=pass;"
dBase "Driver={microsoft dbase driver(*.dbf)};driverid=277;dbq=------------;"
oracle "Driver={microsoft odbc for oracle};server=oraclesever.world;uid=admin;pwd=pass;"
MSSQL server "Driver={sql server};server=servername;database=dbname;uid=sa;pwd=pass;"
MS text "Driver={microsoft text driver(*.txt; *.csv)};dbq=-----;extensions=asc,csv,tab,txt;Persist SecurityInfo=false;"
Visual Foxpro "Driver={microsoft Visual Foxpro driver};sourcetype=DBC;sourceDB=*.dbc;Exclusive=No;"
MySQL "Driver={mysql};database=yourdatabase;uid=username;pwd=yourpassword;option=16386;"
SQLite "Driver={SQLite3 ODBC Driver};Database=D:\SQLite\*.db"
PostgreSQL "Driver={PostgreSQL ANSI};server=127.0.0.1;uid=admin;pwd=pass;database=databaseName"