Модераторы: korob2001, ginnie
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Perl + DBD::ODBC + Firebird, Сопряжение Perl и Firebird  
:(
    Опции темы
Gain
Дата 22.12.2011, 15:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 13.10.2010

Репутация: нет
Всего: нет



Windows 7
Perl 5.14
Firebird 2.1.3 установлен на сервере, база данных лежит там же

Код

#!/usr/bin/perl -w

use DBI;
use DBD::ODBC;

my($driver) = "Firebird/InterBase(r) driver"; # имя ODBC драйвера, скачан с официального сайта Firebird
my($server) = "ab"; # имя сервера
my($user) = "sysdba"; # логин
my($password) = "masterkey"; # пароль
my($database) = 'g:\np_g\ab20.gdb'; # путь к базе данных (ЗДЕСЬ ОШИБКА)
my($connexion) = "ODBC";
my(%DSN) =
(
    ODBC => {
        dsn => "Driver={$driver};Server=$server;Database=$database;uid=$user;pwd=$password;",
        heading => 'Using ODBC Driver Manager via DBI::ODBC',
        mode => 'ODBC',
    }
);
my($connect) = "dbi:$DSN{$connexion}{'mode'}(RaiseError=>0, PrintError=>0, Taint=>0):$DSN{$connexion}{'dsn'}";
my($dbh) = DBI->connect($connect, { PrintError => 0, AutoCommit => 0 }) || die("Can't connect: $DBI::errstr");


Can't connect: [ODBC Firebird Driver]File Database is not found (SQL-08004) [state was 08004 now 01S00]
[ODBC Firebird Driver]Invalid connection string attribute (SQL-01S00) at D:\Sendbox\perl\DB\firebird.pl line 38.


Как правильно указать путь к базе данных?
PM MAIL   Вверх
arto
Дата 22.12.2011, 16:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1495
Регистрация: 31.10.2004

Репутация: 38
Всего: 40



g:/np_g/ab20.gdb ?
PM MAIL ICQ   Вверх
Gain
Дата 22.12.2011, 16:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 13.10.2010

Репутация: нет
Всего: нет



да, этот путь не прокатывает почему-то, хотя база точно там лежит
может я синтаксически неправильно указываю путь к базе?
можно как-то проанализировать этот момент?
В IBExpert я указывают в поле Database file такое значение: g:\np_g\ab20.gdb
и все прекрасно подключается

Это сообщение отредактировал(а) Gain - 22.12.2011, 16:52
PM MAIL   Вверх
Pfailed
Дата 22.12.2011, 17:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 933
Регистрация: 19.7.2009

Репутация: 22
Всего: 39



В документации ODBC драйвера firebird имя базы предлагается указывать так:
DBNAME=server:c:\db.fdb

В вашем случае будет:
DBNAME=ab:g:\np_g\ab20.gdb



--------------------
PM MAIL   Вверх
Gain
Дата 22.12.2011, 17:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 13.10.2010

Репутация: нет
Всего: нет



боже, храни королеву
спасибо
PM MAIL   Вверх
tishaishii
Дата 12.1.2012, 21:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Создатель
***


Профиль
Группа: Завсегдатай
Сообщений: 1262
Регистрация: 14.2.2006
Где: Москва

Репутация: 4
Всего: 8



DBD::ODBC для многих пользователей Firebird не подходит. Сломано множество штыков, копей, стрел, клавиатур. Начиная с версии FB 1.5.
Однозначно используй DBD::InterBase. Работает быстро и стабильно.
PM MAIL ICQ Skype   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Perl"
korob2001
sharq
  • В этом разделе обсуждаются общие вопросы по языку Perl
  • Если ваш вопрос относится к системному программированию, задавайте его здесь
  • Если ваш вопрос относится к CGI программированию, задавайте его здесь
  • Интерпретатор Perl можно скачать здесь ActiveState, O'REILLY, The source for Perl
  • Справочное руководство "Установка perl-модулей", можно скачать здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, korob2001, sharq.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Perl: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1146 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.