Столкнулся с проблемой кодировки при переходе из MySQL 4 в MySQL 5.
Это вечная проблема, которая возникает при переходе из одной версии MySQL в другую и связана с поддерживаемыми кодовыми страницами.
При переходе из MySQL 3 в MySQL 4 была проблема с кодировками, т.к. в MySQL 3 они не указывались, а в MySQL 4 стали указываться.
При переходе же из версии MySQL 4 в MySQL 5 проблема связана с тем, что в 5-й версии уже используется универсальная кодировка utf-8.
В этом же форуме, я хочу подбить определённый результат, как эту проблему решить.
1. Прежде всего, нужно указать по умолчанию русские кодировки.
2. После вызова коннекта в PHP необходимо указать, что кодировка, например, cp1251
Так, например, в phpNuke я указал в файле mainfile.php после коннекта:
// Rudjuk 24.06.2007 Change Error Code
if ($db){
$db->sql_query(“set names ‘cp1251′”);
}
После этого должно работать.
Кстати, при переносе данных из одного сервера, скажем MySQL 4 на другой с MySQL 5 следует обязательно после коннекта к базе (вначале дампа) указать:
Код
SET NAMES CP1251
Еще осталась проблема с автоматическим определением кодировки.
Почему-то по умолчанию определяется на странице, что кодировка utf-8, хотя указано явно
Код
< meta http-equiv=”content-type” content=”text/html; charset=windows-1251″ />
В apache2 указывается кодировка по умолчанию в файле /etc/apache2/conf.d/charset, нужно просто вместо UTF-8 указать
AddDefaultCharset windows-1251
Что и говорить проблемы с кодировкой – часто встречаемая проблема.
Как её решить, прекрасно описано в статье: Решение проблем с кодировкой
Какая кодировка настроена в MySQL вы можете узнать с помощью запроса:
Код
SHOW VARIABLES LIKE ‘character_set_client’;
Кроме того, когда создаёте базу и таблицы не забывайте указывать кодировки, например:
Код
CREATE DATABASE inv2_neru
CHARACTER SET cp1251 COLLATE cp1251_bin COLLATE cp1251_bin;
^
CREATE TABLE ibf_admin_login_logs
(
admin_id
int(10) NOT NULL auto_increment,
admin_ip_address
varchar(16) NOT NULL default ‘0.0.0.0’,
admin_username
varchar(40) NOT NULL default ”,
admin_time
int(10) unsigned NOT NULL default ‘0’,
admin_success
int(1) unsigned NOT NULL default ‘0’,
admin_post_details
text,
PRIMARY KEY (admin_id
),
KEY admin_ip_address
(admin_ip_address
),
KEY admin_time
(admin_time
)
) TYPE=MyISAM AUTO_INCREMENT=84 CHARACTER SET cp1251 COLLATE cp1251_bin;
^
https://corp2.info/razrabotka-i-sozdanie-sajtov-internet-magazinov-veb-proektov-kiev-1038.html
Leave a Reply