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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Странная ошибка при обращении к базе. 
:(
    Опции темы
perlovka1
Дата 19.4.2009, 07:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Добрый день!

Проблема следующая. Есть код запроса в базу данных Postgres:
Код

$dbh = DBI->connect("DBI:Pg:dbname=$dbname;host=$dbhost;port=$dbport", "$dbuser", "$dbpass", {PrintError => 0}) or die;
$query = qq~тело sql-запроса;~;
$sth = $dbh->prepare($query);
$rv = $sth->execute() or die;
while (@row = $sth->fetchrow_array) {(здесь вывод данных через print)}


При выполнении данного кода из CGI, скрипт делает die на строке $rv = $sth->execute() or die;

Если этот же код запускать из командной строки, то всё работает хорошо, данные из базы извлекаются.

Есть ещё одна база с аналогичной структурой, отличается только именем, владельцем и данными. При обращении к этой базе CGI-скрипт не умирает.

С правами порядок, иначе die был бы на стадии коннекта к базе. С запросом тоже порядок, т.к. он выполняется из командной строки, а также через PgAdmin III.

В чём проблема, понять не могу. Кто-нибудь может подсказать? Заранее спасибо!
PM MAIL   Вверх
arto
Дата 19.4.2009, 08:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



die $dbh->errstr ?
PM MAIL ICQ   Вверх
sir_nuf_nuf
Дата 20.4.2009, 11:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Скорее всего в проблема в переменных окружения.
При работе в CGI режиме - они переназначаются.

При подключении к базе данных клиент (драйвер) пытается получить хост \ порт \ имя базы \ имя юзера
из параметров, если не удается - из переменных окружения
PGHOST
PGPORT
PGDATABASE
PGUSER

В командной строке - эти переменные проставлены, в CGI - нет.
Сравните их.

А еще проверьте dbname=$dbname - скорее всего имя базы задается не так


--------------------
user posted image
user posted image
PM MAIL Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Perl"
korob2001
sharq
  • В этом разделе обсуждаются общие вопросы по языку Perl
  • Если ваш вопрос относится к системному программированию, задавайте его здесь
  • Если ваш вопрос относится к CGI программированию, задавайте его здесь
  • Интерпретатор Perl можно скачать здесь ActiveState, O'REILLY, The source for Perl
  • Справочное руководство "Установка perl-модулей", можно скачать здесь


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

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


 




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


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

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