2014-10-04 71 views
2

我在Windows 7 64位机器上使用perl 5.18.1.1800和ppm 4.19。为Perl 5.18.xx安装DBI-mysql

我需要使用DBD-mysql才能从perl访问mysql。但我得到以下错误信息:

use DBI(); 
my $dbh = DBI->connect("DBI:mysql:database=mydbname;host=localhost","myuser", "mypass",{'RaiseError' => 1}) 

install_driver(MySQL的)失败:@公司无法找到CAD/mysql.pm(您 可能需要安装DBD :: mysql的模块)

所以我试图安装DBD-mysql,但我没有在我的PPM中列出。在命令行中,当我尝试安装,我得到以下错误

ppm install DBD-mysql 

PPM安装失败:无法找到提供DBD-mysql的

我试图下载和安装任何包它,但它需要一个我没有的C编译器。

DBD-mysql info page,没有提到模块的Perl 5.18支持。

那么,我应该恢复到5.16.xx还是其他问题呢?

谢谢,

回答

2

DBD-MySQL适用的activeperl-5.16.3.1604。恢复到该版本可能比安装编译器自己构建软件包更简单。

ActiveState的使用Visual Studio来构建DBD-mysql的:http://ppm4.activestate.com/MSWin32-x86/5.16/1600/C/CA/CAPTTOFU/DBD-mysql-4.022.d/log-20120830T032945.txt

enter image description here

C:\>ppm install DBD-mysql 
Downloading ActiveState Package Repository packlist...done 
Updating ActiveState Package Repository database...done 
Syncing site PPM database with .packlists...done 
Downloading DBD-mysql-4.022...done 
Unpacking DBD-mysql-4.022...done 
Generating HTML for DBD-mysql-4.022...done 
Updating files in site area...done 
    12 files installed 
+0

运行'C:\> ppm的安装DBD-mysql'在命令提示符下完美地工作! – Navigatron 2015-04-14 12:00:15

0

该模块的名称是DBI。尝试使用:

ppm install DBI 

*免责声明:我没有使用Perl的Windows上,而Perl的在Linux上,所以我以为语法使用PPM是“PPM安装模块名”。

也,语法以下正确的是:

my $dbh = DBI->connect(DBI:mysql:DBNAME, $username, $pass, {RaiseError => 1, AutoCommit 
=> 1}) or die "Could not Connect to DB";