1. 程式人生 > >linux(debian)系統django配遠程連接sqlserver數據庫

linux(debian)系統django配遠程連接sqlserver數據庫

限制 ng-click 是否 art 數據庫名 sin space 變量 安裝python

費了將近一天時間。最終解決,記下來留給須要的人

須要安裝的:

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數據庫