linux(debian)系统django配远程连接sqlserver数据库

费了将近一天时间,终于解决,记下来留给需要的人

需要安装的:

python-odbc : https://github.com/mkleehammer/pyodbc下载后install

安装python-odbc的如果报找不到sql.h文件错误,需要apt-get install g++,

这块代码是用C++写的,需要编译器

django-pyodbc : https://pypi.python.org/pypi/django-pyodbc 下载后install

unixODBC:http://www.unixodbc.org/. linux下的odbc数据库源

安装:./configure & make & make install

或者 apt-get install unixODBC unixODBC-dev

FreeTDS:http://www.freetds.org/ linux下的sqlserver驱动程序

安装:./configure --prefix=/usr/local/freetds --with-tdsver=8.0 --enable-msdblib --with-gnu-ld --enable-shared --enable-static

make & make install

apt-get install freetds freetds-dev tdsodbc

配置:

1.配置FreeTDS

找到 freetds.conf下面添加:

[MYSQLSERVER]

host = sqlserver服务器IP

port = 1433

tds version = 8.0

client charset = UTF-8

把 tsql所在目录加入环境变量 如我的操作:vim /etc/profile 加一行PATH=$PATH:/usr/local/freetds/bin

再source /etc/profile 使其马上生效

测试FreeTDS是否安装成功:

tsql -C 看安装环境

tsql -S MYSQLSERVER -H sqlserver数据库IP -p 1433 -U 账号 -P 密码

成功会看到如下信息:

locale is "en_US.UTF-8"

locale charset is "UTF-8"

using default charset "UTF-8"

1>

这时输入sql命令测试一下吧:

use test_db

go

select * from test;

go

安装成功后再继续下一步吧

2.配置unixODBC

找到odbc.ini odbcinst.ini

我的在/etc/odbc.ini /etc/odbcinst.ini

vim /etc/odbcinst.ini加入

[FreeTDS]

Description = ODBC of FreeTDS for MS-SQLServer

Driver = /usr/local/freetds/lib/libtdsodbc.so

FileUsage = 1

vim /etc/odbc.ini加入

[odbc连接名]

Driver = FreeTDS

ServerName = MYSQLSERVER(FreeTDS里配的连接名)

Database = test_db(数据库名)

测试unixODBC是否安全配置成功:

isql -v odbc连接名 账号 密码

成功后会出现如下信息:

+---------------------------------------+

| Connected!                            |

|                                       |

| sql-statement                         |

| help [tablename]                      |

| quit                                  |

|                                       |

+---------------------------------------+

SQL>

写几个sql语句测试下吧,不过这次不用再use test_db了,因为已经配过数据库名称了

select * from test

也不用go了,呵呵

3.安装完python-odbc和django-pyodbc后,配置django的setting(安装不说了,比较简单)

‘kids‘: {

‘ENGINE‘: ‘django_pyodbc‘,

‘NAME‘: ‘数据库名‘, #这个不需要,不过django里有限制,必须有NAME项,这里不会生效,实际的在odbc.ini里写的

‘USER‘: ‘账号‘,

‘PASSWORD‘: ‘密码‘,

‘HOST‘: ‘‘, #这个也不会生效,实际生效的是freetds.conf里配置的

‘OPTIONS‘:{

‘driver‘: ‘FreeTDS‘,

‘dsn‘:‘odbc连接名‘, #ODBC DSN name defined in your odbc.ini,

}

over!

时间: 2024-10-16 10:09:26

linux(debian)系统django配远程连接sqlserver数据库的相关文章

Linux系统下实现远程连接MySQL数据库的方法教程

1.在服务器端开启远程访问首先进入mysql数据库,然后输入下面两个命令: grant all privileges on *.* to 'root'@'%' identified by 'password';flush privileges;第一个*是数据库,可以改成允许访问的数据库名称第二个 是数据库的表名称,代表允许访问任意的表root代表远程登录使用的用户名,可以自定义%代表允许任意ip登录,如果你想指定特定的IP,可以把%替换掉就可以了password代表远程登录时使用的密码,可以自定

window系统服务器,远程连接mysql数据库。

1.修改一下MySQL端口号,避免防火墙禁止3306端口对外开放:在my.ini配置文件中 2.创建一个mysql用户, 然后给他权限, mysql -u root -p //登录MySQL mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION; //任何远程主机都可以访问数据库 mysql> FLUSH PRIVILEGES; //需要输入次命令使修改生效 mysql> EXIT //退出

[计算机网络] Linux下使用corkscrew进行远程连接

最近重装了电脑,使用ssh远程连接机房的机器时,发生连接超时,再ping机房的机器,没有回应,也就是说我的电脑和机房的电脑不是连通的,再ping机房的网关,却可以ping通.于是,就需要找一种通过代理来连接机房的方法:corkscrew. 1 安装corkscrew sudo apt-get install corkscrew 2 配置corkscrew 在用户主目录下新建.corkscrew-auth,将远程机器的用户名和密码以下面的格式放在里面: username:passwd 在用户主目录

Linux下开启MySQL的远程连接

Linux下开启MySQL的远程连接 基于安全考虑root账户一般只能本地访问,但是在开发过程中可能需要打开root的远程访问权限.下面是基本的步骤: 1.登录到mysql中,为root进行远程访问的授权,执行下面的命令: mysql> GRANT ALL PRIVILEGES ON *.* TO [email protected]"%" IDENTIFIED BY "root"; mysql> flush privileges; 第一句中"%

linux学习记录-------mysql授权远程连接

Linux开启MySQL远程连接的设置步骤 . MySQL默认root用户只能本地访问,不能远程连接管理MySQL数据库,那么Linux下如何开启MySQL远程连接? 设置步骤如下: 1.登陆mysql 2.执行命令授权:GRANT ALL PRIVILEGES ON *.* TO 'user'@'%'IDENTIFIED BY 'password' WITH GRANT OPTION; user:用户名 %:代表所有ip,可换成指定ip, password:密码 即授权给user用户在指定ip

解决Ubuntu系统下 mysql 远程连接失败的问题 ERROR 2003 (HY000): Can't connect to MySQL server on 'xxx.xxx.xx.xx' (110)

如果远程连不上mysql.cnf 里面也修改了:bind注销掉了127.0.0.1 等所有的 但是telnet xxx.xxx.xx.xx 3306 端口 不通:那么 就是防火墙的问题了 1.修改Ubuntu系统防火墙规则 [[email protected] ubuntu]#vim /etc/iptables.rules 解决Ubuntu系统下 mysql 远程连接失败的问题 ERROR 2003 (HY000): Can't connect to MySQL server on 'xxx.x

远程连接db2数据库

在db2数据库中,需要理解catalog(编目)这个概念,理解前先说下db2数据库的体系结构:由系统(节点)也就是主机,下面是实例,实例下面是数据库,然后是表空间,再是数据库对象.现在假设你有一个数据库服务器建立在MDMNODE1 的机器上,你有一个客户端在windows.linux或任何平台上,你现在想建立一个客户端到服务器端的连接,具体步骤如下: <第一步> 要在客户端的机器上能够把远程的服务器能够识别出来,怎么做? 在DB2使用编目(catalog)方式,具体来说就是通过编目把远程的服务

C#远程连接Oracle数据库(通过System.Data.OracleClient)

在.NET中使用System.Data.OracleClient库连接Oracle数据库的步骤 1.下载并安装Instant Client Instant Client可以在Oracle官方网站下载到 对于Windows,Instant Client有三种版本: 1)适用于 Microsoft Windows(32位)的 Instant Client 2)适用于 Microsoft Windows(64位)Itanium的 Instant Client 3)适用于 Microsoft Windo

局域网内任何一台pc上windows下eclipse远程连接hbase数据库

通过很长一段时间的反复失败,终于在windows下实现远程连接hbase数据库,在不断的尝试过程中深感一个详细的文档的重要性,于是就把我配置的详细过程记录下来.文中如果有些地方用词不当,或者理解错误,欢迎您们评论. 一.运行平台 hbase服务器端:Ubuntu 14.04 64位:HBASE1.1.3:JAVA 1.8: hbase客服端:windows32/64位:JAVA1.8:eclipse 4.5: 二.linux服务器端环境配置 1.  安装java 1.8软件 1)下载java软件