Ошибка Perl API: использование ключевого слова "SQL_INTEGER" во время использования "строгих подпрограмм"
Я пытаюсь подключиться к API Ensembl, используя следующий код Perl:
#!/bin/perl
use Bio::EnsEMBL::Registry;
use DBI qw(:sql_types);
my $registry = 'Bio::EnsEMBL::Registry';
$registry->load_registry_from_db(
-host => 'ensembldb.ensembl.org', # alternatively 'useastdb.ensembl.org'
-user => 'anonymous'
);
my @db_adaptors = @{ $registry->get_all_DBAdaptors() };
foreach my $db_adaptor (@db_adaptors) {
my $db_connection = $db_adaptor->dbc();
printf(
"species/group\t%s/%s\ndatabase\t%s\nhost:port\t%s:%s\n\n",
$db_adaptor->species(), $db_adaptor->group(),
$db_connection->dbname(), $db_connection->host(),
$db_connection->port()
);
}
Bioperl и CPAN оба обязаны использовать API Ensembl, и я уверен, что они правильно установлены на моем Ubuntu. Я также добавил необходимые модули в переменную окружения PERL5LIB. Несмотря на все это, я получаю следующее сообщение об ошибке:
Bareword "SQL_INTEGER" not allowed while "strict subs" in use at /home/src/ensembl/modules/Bio/EnsEMBL/DBSQL/BaseAdaptor.pm line 299.
Compilation failed in require at /home/src/ensembl/modules/Bio/EnsEMBL/DBSQL/BaseFeatureAdaptor.pm line 45.
BEGIN failed--compilation aborted at /home/src/ensembl/modules/Bio/EnsEMBL/DBSQL/BaseFeatureAdaptor.pm line 45.
Compilation failed in require at /home/src/ensembl/modules/Bio/EnsEMBL/DBSQL/DBAdaptor.pm line 60.
BEGIN failed--compilation aborted at /home/src/ensembl/modules/Bio/EnsEMBL/DBSQL/DBAdaptor.pm line 60.
Compilation failed in require at /home/src/ensembl/modules/Bio/EnsEMBL/Registry.pm line 127.
BEGIN failed--compilation aborted at /home/src/ensembl/modules/Bio/EnsEMBL/Registry.pm line 127.
Вот файл реестра, который скрипт использует для подключения к базам данных Ensembl:
Bio::EnsEMBL::Registry->load_registry_from_db(
-host => 'ensembldb.ensembl.org',
-user => 'anonymous',
-verbose => '1'
);
use strict;
use Bio::EnsEMBL::Utils::ConfigRegistry;
use Bio::EnsEMBL::DBSQL::DBAdaptor;
new Bio::EnsEMBL::DBSQL::DBAdaptor(
-host => 'ensembldb.ensembl.org',
-user => 'anonymous',
-port => '3306',
-species => 'homo_sapiens',
-group => 'core',
-dbname => 'homo_sapiens_core_70_37'
);
my @aliases = ( 'H_Sapiens', 'Homo sapiens', 'human' );
Bio::EnsEMBL::Utils::ConfigRegistry->add_alias(
-species => 'homo_sapiens',
-alias => \@aliases
);
1
1 ответ
Есть ли в файле /home/src/ensembl/modules/Bio/EnsEMBL/DBSQL/BaseAdaptor.pm строка use DBI qw(:sql_types);
до строки 299? Нет? Может быть, у вас есть старая версия Bio::EnsEMBL::DBSQL::BaseAdaptor.
Может быть, ваш DBI не то, что он должен быть. Что значит perldoc -l DBI
скажем, местоположение DBI? Это правильно? Как вы установили DBI? Вы не просто скопировали файлы.pm, не так ли?