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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> кодировка (koi8-r) perl-mysql 
V
    Опции темы
ichar
Дата 25.6.2009, 23:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Помогите понять причину. Не "читаются" русские символы из таблицы MySQL в perl-скрипте. Данные записаны в кодировке KOI8-R. Читаю указанную таблицу perl-скриптом (DBI), вместо русских символов получаю знак вопроса '?': 

Код: 
Код

use DBI; 
... 
my $dsn = "DBI:mysql:database=$database;host=$hostname;port=3306"; 

my $dbh = DBI->connect($dsn, $user, $password, {'RaiseError' => 1}); 
my $sth = $dbh->prepare("SELECT attrValue FROM ..."); 
$sth->execute(); 

while (my $ref = $sth->fetchrow_hashref()) { 
  print "$ref->{'attrValue'}\n"; 

... 
 

Результат (для всех записей примерно одно и то же): 
???????? ?????????? 

Проверяю по-символьно полученные данные: 
...
print ord($_) foreach split('', $value); 

636363636363636363326363636363636363636332 

т.е. в таком виде данные приходят от сервера mysql. В таблице нормальный русский текст.

Перекодировка результата не дает: 

Код: 
Код

use Encode; 
... 
# вариант 1) 
my $value = decode("cp1251", $ref->{'attrValue'}); 
... 
# вариант 2) 
Encode::from_to($value, "koi8-r", "cp1251"); 
 

Спасибо!
PM MAIL   Вверх
DaemonSuw
Дата 26.6.2009, 09:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



попробуйте после коннекта к базе данных добавить строки 

Код

dbh->do("SET NAMES 'koi8-r'")
dbh->do("SET CHARACTER SET koi8-r")


А потом делайте encode/decode
PM MAIL ICQ   Вверх
ichar
Дата 26.6.2009, 13:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Да, точно. Достаточно добавить 

SET NAMES 'koi8-r'

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


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

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


 




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


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

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