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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> DBD::Pg уточнение запроса по типу поля "inet" 
:(
    Опции темы
n00zdri
Дата 27.8.2010, 00:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Всем привет, у меня тут вот такая вот засада:

Код

foreach my $ip_for_add (@bonly) {
    my $query_for_natid = $dbh_for_natid->prepare("SELECT nat_id FROM subnets WHERE addr>>'$ip_for_add'");
    $query_for_natid->execute();
    while (@row_natid = $query_for_natid->fetchrow_array()) {
        ($natid) = @row_natid;
...
...

 
В консоль мне выплёвывает вот так: 

Код

DBD::Pg::st execute failed: ERROR:  invalid input syntax for type inet: "10.4.8.243
" at ./pbrcfg.pl line 59.
DBD::Pg::st fetchrow_array failed: no statement executing at ./pbrcfg.pl line 62.


В psql запрос прокатывает. Если вместо переменной $ip_for_add в запросе задать, например '10.4.8.243' - запрос прокатывает, что в принципе тоже самое, что и хранится в этой переменной. Понятно, что postgres ругается на недопустимое значение для типа 'inet', но что я делаю не так? Такое ощущение, что в массиве как то по другому хранится этот айпи.
PM MAIL   Вверх
DurRandir
Дата 27.8.2010, 01:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



1. Вставлять напрямую неэкранированную переменную в запрос - очень, очень, очень, очень плохо. 
2. То, что кавычка в строке ошибки закрывается на следующей строке - намекает на \r?\n в переменной $ip_for_add. 

Это сообщение отредактировал(а) DurRandir - 27.8.2010, 01:22
PM   Вверх
dva300
Дата 27.8.2010, 10:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



В MySQL есть метод quote() для таких случаев. 
Он же есть и в PG
--------------------
Участник движения Культура Вождения
PM   Вверх
n00zdri
Дата 27.8.2010, 18:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(DurRandir @ 27.8.2010,  01:22)
1. Вставлять напрямую неэкранированную переменную в запрос - очень, очень, очень, очень плохо. 
2. То, что кавычка в строке ошибки закрывается на следующей строке - намекает на \r?\n в переменной $ip_for_add.

Спасибо, помогло.

2dva300 Спасибо за отклик.

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


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

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


 




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


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

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