Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: MySQL && UTF-8
 
 автор: sms-send   (28.04.2007 в 23:23)   письмо автору
 
 

Вот описание таблицы:

CREATE TABLE `msgs` (
  `id` int(11) NOT NULL auto_increment,
  `time` timestamp NOT NULL default CURRENT_TIMESTAMP,
  `ip` varchar(20) character set utf8 NOT NULL,
  `host` varchar(30) character set utf8 NOT NULL,
  `msisdn` varchar(15) character set utf8 NOT NULL,
  `uagent` varchar(50) character set utf8 NOT NULL,
  `name` varchar(30) character set utf8 NOT NULL,
  `email` varchar(30) character set utf8 NOT NULL,
  `text` varchar(255) character set utf8 NOT NULL,
  `answer` varchar(255) character set utf8 NOT NULL,
  KEY `id` (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=26 ;


Скрипт работает в кодировке UTF-8.

Текст приходит из формы и записывается в базу в нормальном виде (текст "ИмяИмя"):
D0 98 D0 BC D1 8F D0 98 D0 BC D1 8F
А вот это уже возвращает база, при выборке:
D0 3F D0 BC D1 8F D0 3F D0 BC D1 8F

Изменяются только некоторые кирилические символы (например, "И", байты "D0 98" меняются на "D0 3F").

В чём дело?

   
 
 автор: cheops   (29.04.2007 в 01:52)   письмо автору
 
   для: sms-send   (28.04.2007 в 23:23)
 

При выборке устанавливаете кодировку соединения при помощи запроса?
SET NAMES utf8;

   
 
 автор: sms-send   (30.04.2007 в 08:49)   письмо автору
 
   для: cheops   (29.04.2007 в 01:52)
 

Сейчас попробовал, но ничего не изменилось. Вот phpinfo

   
 
 автор: sms-send   (01.05.2007 в 16:42)   письмо автору
 
   для: cheops   (29.04.2007 в 01:52)
 

Кстати, заметил, что это происходит только с заглавной буквой "И". Выход: просто реплейсить этот байт на верный.

И всё же почему так происходит? Хоть кто предположить может?

   
 
 автор: Unkind   (01.05.2007 в 18:47)   письмо автору
 
   для: sms-send   (01.05.2007 в 16:42)
 

Кодировка должна быть utf8_general_ci. Желательно еще:


<?php
mysql_unbuffered_query
("SET `character_set_client` = 'utf8';");
mysql_unbuffered_query("SET `character_set_results` = 'utf8';"); 
mysql_unbuffered_query("SET `collation_connection` = 'utf8_general_ci';");
?>

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования