Linux上Perl连接Windows上的SQL server包括字符集乱码踩坑

本文介绍了如何在Linux环境中使用Perl通过ODBC连接Windows上的SQL Server,详细讲述了配置过程,包括安装unixODBC、freetds和DBD-ODBC,以及解决字符集乱码问题的关键步骤。在配置freetds时,选择正确的tds版本,并在odbc.ini中使用服务器别名而不是IP来避免字符编码问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Perl 连接SQL server数据库

  • 作者:assesion
    perl这套东西真是让人头大,这次使用Perl的catalyst框架做一个数据导出工作遇到了一些麻烦,网上很难找到关于catalyst的资料,真是难为人,Linux系统下的Perl怎么连接Windows上的SQL server数据库,在Linux下安装一个SQL server数据库再把数据导入吗?显然这是很愚蠢的方法。配好环境后一顿开心结果遇到字符集乱码问题凉凉,所以注意后面的freetd配置步骤

环境配置

环境配置很关键也很多坑

需要的模块

unixodbc(Linux系统的ODBC)下载地址
freetds 或者(Sybase的驱动) 下载地址
DBD-ODBC(Perl的ODBC) 下载地址
本次测试安装的版本 DBD-ODBC-1.43 freetds-0.82 unixODBC-2.3.7(数据库版本不同可能需要改变模块的版本)SQL server2008R2数据库以及Perl5.6

安装

1.安装unixODBC

tar vxzf unixODBC-2.2.8.tar.gz
cd unixODBC-2.2.8
./configure --prefix=/xxx/xxx/unixODBC (安装路径)
make
m

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值