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

Posted zhchoutai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 password

成功会看到例如以下信息:

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连接名 账号 password

成功后会出现例如以下信息:

+---------------------------------------+
| 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‘: ‘password‘,
? ? ? ? ‘HOST‘: ‘‘, #这个也不会生效,实际生效的是freetds.conf里配置的
? ? ? ? ‘OPTIONS‘:{
? ? ? ? ? ? ? ? ‘driver‘: ‘FreeTDS‘,
? ? ? ? ? ? ? ? ‘dsn‘:‘odbc连接名‘, #ODBC DSN name defined in your odbc.ini,
? ? ? ? }

over!



以上是关于linux(debian)系统django配远程连接sqlserver数据库的主要内容,如果未能解决你的问题,请参考以下文章

运维部署自动化实践(二)PXE+Preseed自动安装Ubuntu16.04 server

如何linux 远程桌面访问windows。

Django环境搭建及学前准备

远程连接Linux虚拟机上的mysql失败的解决方法

Deepin Forum 61 请问一下深度的Linux怎么开启VNC远程桌面

服务器配制成允许远程连接