Проблема с кодировкой PHP <--> MySQL

кодировка iconv

Помогите решить проблему, связанную с кодировкой. Когда сохраняю данные, полученные от пользователя (CP1251) в MySQL (UTF-8), использую iconv('CP1251','UTF-8',$data); но в таблице, вместо кирилицы всякая белиберда. Как с этим бороться?
Ответы:
к примеру:
$sql = mb_convert_encoding($sql, "UTF-8", "cp1251");
была подобная проблема при работе с AJAX, спасла эта строка перед сохранением в базу:
Зачем хранить базу и клиент часть в разных кодировках?
Попробуйте mysql_query("SET NAMES CP1251");
После установки соединения с БД сделайте запрос SET NAMES cp1251 COLLATE cp1251_general_ci
Но лучше всего писать само приложение в UTF-8 (будет меньше проблем с кодировками, плюс можно будет хранить данные на любом языке, да и зачем иначе UTF в базе?)


15 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.