• shell for MSSQL:

    • https://github.com/dbcli/mssql-cli
    • mssql-cli -S 127.0.0.1,1433 -d testDB -U myuser -P mypass -Q "select @@version;select * from account"

      记住输出的sql server的服务器版本.我这里是Microsoft SQL Server 2014.
  • python for MSSQL:
    • 安装环境:ubuntu18.

    • 安装linux下的ODBC驱动管理器:

      • sudo apt-get update
      • sudo apt-get install unixodbc unixodbc-dev (unixodbc-dev是必须的!)
      • odbcinst -j 测试安装成功
    • 安装freetds(支持MSSQL的ODBC驱动):

      • 前言: 作为可选的一个替代方案,也可以安装微软的驱动:https://docs.microsoft.com/zh-cn/sql/connect/odbc/linux-mac/installing-the-microsoft-odbc-driver-for-sql-server?view=sql-server-2017 (网上比较推荐freetds驱动.我们服务器用的Microsoft ODBC Driver 13.也成功了.下面仅讲述freetds驱动的安装步骤)
      • sudo apt-get remove freetds-bin freetds-common freetds-dev (必须卸载先!必须通过编译的方式安装!不要用apt-get安装freetds!)
      • 在这里查看最新的freetds下载地址:http://www.freetds.org/software.html
      • 安装:
        • wget ftp://ftp.freetds.org/pub/freetds/stable/freetds-1.3.12.tar.gz
        • tar zxf freetds-1.3.12.tar.gz
        • cd freetds-1.3.12/
        • ./configure --prefix=/usr/local/freetds --with-unixodbc=/usr/ --enable-msdblib --with-gnu-ld --enable-shared --enable-static

          注意:因为前面的ODBC驱动管理器是通过apt-get安装的,所以--with-unixodbc=就在/usr/下(有/usr/bin/odbcinst)。
        • sudo make && sudo make install
        • sudo ln -s /usr/local/freetds/bin/tsql /usr/bin/tsql
      • 测试安装成功:
        • tsql -C
        • tsql -H 127.0.0.1 -p 1433 -U myuser -P mypass
            1> select @@version
        2> go # go这个命令才会执行前面的sql语句.
        1> quit

        上面的命令,记住查询到的sql server服务器的版本. 我这里是Microsoft SQL Server 2014.

        http://www.freetds.org/userguide/ChoosingTdsProtocol.html

        在这个网址里可以查到sql server的版本对应的freetds协议号,可以看到2014对应的协议号是7.4(记住)

      • 配置freetds:
        • sudo vi /usr/local/freetds/etc/freetds.conf
            [global]里面加一行: client charset = UTF-8  # 避免中文乱码
        然后,最下面有个“port = 1433”的章节,这个端口是MSSQL的默认端口.改一下这个章节的名字为MSSQL(要记住):
        如下:
        [MSSQL] # 改动.
        host = 127.0.0.1 # 改动.
        port = 1433 # 没改
        tds version = 7.4 # 改动.
      • 为ODBC驱动管理器添加上freetds驱动:
        • sudo vi /etc/odbcinst.ini

          编辑如下:
        [ODBC]
        Trace = No
        TraceFile = /tmp/sql.log
        ForceTrace = No
        Pooling = Yes [FreeTDS]
        Description = FreeTDS Driver
        Driver=/usr/local/freetds/lib/libtdsodbc.so
        • sudo vi /etc/odbc.ini

          编辑如下:
        [ms-sql]                # 对应connect字符串中的DSN
        Driver = FreeTDS # 这个和odbcinst.ini里的章节名儿对应起来.
        Servername = MSSQL # 这个和上面配置的freetds.conf里的章节名儿对应起来.
      • 配置完成后测试:
        • 使用 isql 测试一下,测试方式是执行:
        isql -v ms-sql username password # 必须加上user和pass。。否则连不上提示也奇怪。。

        也可以批量执行sql语句:

        isql -v ms-sql myuser mypass -w < my.sql > 1.html  # 输出结果到html文件
    • 安装pyodbc:

      • 建议python3,py2中的默认编码是ASCII码,py3默认编码是Unicode(utf-8).因此不需要在文件头部写"# coding=utf-8"了。
      • sudo pip3 install pyodbc (如果timeout则多试几遍...)
      • 测试:
        • python3:
            - import pyodbc
        - pyodbc.drivers()
        # connect时SERVER, SERVERNAME, DSN这三个同时只能设一个,因此有三种connect方法:
        - cnxn = pyodbc.connect('DRIVER=FreeTDS;SERVER=127.0.0.1,1433;DATABASE=testDB;UID=myuser;PWD=mypass') # 推荐
        - cnxn = pyodbc.connect('DRIVER=FreeTDS;Servername=MSSQL;DATABASE=testDB;UID=myuser;PWD=mypass')
        - cnxn = pyodbc.connect('DSN=ms-sql;DATABASE=testDB;UID=myuser;PWD=mypass')
        # 使用:
        - cursor = cnxn.cursor()
        - cursor.execute("select * from account")
        - rows = cursor.fetchall()
        - for row in rows:
        print("{}, {}".format(row.account_name, row.describe))

        详见:https://github.com/mkleehammer/pyodbc/wiki/Getting-started

ubuntu下连microsoft sql server解决方案的更多相关文章

  1. Ubuntu下erlang连接SQL SERVER 2008

    erlang连接SQL Server使用ODBC方法,但在网络上还是缺少资料,自己折腾了2天才成功.现在特记录下来,以供大家借鉴. 基本思路是 erlang odbcserver + unixodbc ...

  2. Zabbix template for Microsoft SQL Server总结

      Zabbix template for Microsoft SQL Server介绍   这里介绍Zabbix下监控Microsoft SQL Server数据库非常好用的一个模板,模板名为&qu ...

  3. sql System.Data.SqlClient.SqlError: 无法覆盖文件 'C:\Program Files\Microsoft SQL Server\MSSQL\data\itsm_Data.MDF'。数据库 'my1' 正在使用该文件的解决方案

    对数据库备份进行还原时遇到“sql System.Data.SqlClient.SqlError: 无法覆盖文件 'C:\Program Files\Microsoft SQL Server\MSSQ ...

  4. Cenots7下安装运行.NET Core、MicroSoft SQL Server 2019 preview 的基础实践

    一:概要 适应人群:.Net初学者.想了解.Net Core在Linux系统中的运行环境搭建者.初次且想在linux上应用.Net Core开发应用程序者: 基础技能:了解.NET基础开发技能者.有一 ...

  5. 安装Microsoft SQL server Management Studio Express 2005 错误码是29506解决方案

    安装Microsoft SQL server Management Studio Express 2005,安装程序在安装此软件包时遇到一个错误,这可能表示此软件包有错.错误码是29506”权限问题. ...

  6. 附加数据库时,提示“Microsoft SQL Server,错误: 5120”, 解决方案

    错误的提示内容为:

  7. Microsoft SQL Server on Linux 踩坑指南

    微软用 SQL Server 在 2016 年的时候搞了一个大新闻,宣传 Microsoft ❤️ Linux 打得一众软粉措手不及.但是这还是好事情,Linux 上也有好用的 SQL Server ...

  8. 使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务

    使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务 作者:Nikolay Manchev 分步构建一个跨这些平台的 ...

  9. [转]Microsoft SQL SERVER 2008 R2 REPORT SERVICE 匿名登录

    本文转自:https://www.cnblogs.com/Zouzhe/p/5736070.html SQL SERVER 2008 R2 是微软目前最新的数据库版本,在之前的SQL SERVER 2 ...

随机推荐

  1. IDEA小技巧:Debug条件断点

    今天给大家分享一个IDEA调试过程中的一个小技巧. 先来说说场景,你有没有碰到类似的情况,一个循环结构里,中间某一个情况可能会出错.比如下面的代码结果中,可能执行到第27次的时候,会出现问题. for ...

  2. datasets数据读取器

    #切分数据集 img_dir = train_parameters['img_dir'] file_name = train_parameters['file_name'] df = pd.read_ ...

  3. java过滤器拦截器的执行时机

    https://www.cnblogs.com/shamo89/p/8534580.html https://www.cnblogs.com/juanzila/p/11276067.html

  4. Centos7 搭建 Socks 服务

    Centos7 搭建 Socks 服务 一丶拿到一个动态拨号的服务器还不能使用网络得先打开: pppoe-start 二丶安装命令汇总: 通过yum安装ss5 依赖包: yum install gcc ...

  5. Git删除已提交的文件

    Git删除已提交的文件 Git删除已提交的文件 定位文件 删除文件 参考链接 昨天通过Git Bash提交代码的时候遇到了由于单个文件大小超过100M,导致代码上传失败的问题.考虑到那个大文件是用于训 ...

  6. Primitive Primes - 题解【数学】

    题面 It is Professor R's last class of his teaching career. Every time Professor R taught a class, he ...

  7. CUDA02 - 访存优化和Unified Memory

    CUDA02 - 的内存调度与优化 前面一篇(传送门)简单介绍了CUDA的底层架构和一些线程调度方面的问题,但这只是整个CUDA的第一步,下一个问题在于数据的访存:包括数据以何种形式在CPU/GPU之 ...

  8. docker:registry

    存放docker镜像(mage)的地址,可供人上传下载镜像包: 下载 docker search whalesay --搜索whalesay镜像,该镜像用命令行的形式画了个鲸鱼并说了句话 docker ...

  9. KTL 一个支持C++14编辑公式的K线技术工具平台 - 第六版,支持OpenGL,3D上帝视角俯视K线概貌。

    K,K线,Candle蜡烛图. T,技术分析,工具平台 L,公式Language语言使用c++14,Lite小巧简易. 项目仓库:https://github.com/bbqz007/KTL 国内仓库 ...

  10. 浅尝Spring注解开发_Bean生命周期及执行过程

    Spring注解开发 浅尝Spring注解开发,基于Spring 4.3.12 包含Bean生命周期.自定义初始化方法.Debug BeanPostProcessor执行过程及在Spring底层中的应 ...