设为首页 收藏本站
查看: 1473|回复: 0

[经验分享] linux(debian)系统django配远程连接sqlserver数据库

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-9-2 08:52:44 | 显示全部楼层 |阅读模式
费了将近一天时间,终于解决,记下来留给需要的人
需要安装的:
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!



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-24230-1-1.html 上篇帖子: Linux下无需输入密码自动登陆ssh服务器方法 下篇帖子: centos修改ssh端口
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表