Linux 下连接sqlserver(下)

╄→尐↘猪︶ㄣ 提交于 2020-12-16 04:27:08

基于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"
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!