Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Как правильно прочесть из msql русские сообщения  (Прочитано 9141 раз)
0 Пользователей и 1 Гость смотрят эту тему.
Boriska
Помогающий

us
Offline Offline

« : 30-03-2015 09:13 » 

Привет команда и форумчане.

Нужно прочесть из msql русские сообщения. Создаю таблицу.

Код: (MySQL)
CREATE TABLE messages(
  id INT (11) NOT NULL AUTO_INCREMENT,
  message VARCHAR (100) CHARACTER SET cp1251 COLLATE cp1251_general_ci NOT NULL,
  PRIMARY KEY (id),
  UNIQUE INDEX message USING BTREE (message)
)
ENGINE = INNODB
AUTO_INCREMENT = 7
CHARACTER SET latin1
COLLATE latin1_swedish_ci;

Пытаюсь читать, вылетает исключение. Ранее пока пользовался только латинскими сообщениями все было Ок.
Код: (C++)
CString rq;
CRecordset rs(pDb);
        rq = "Select message From  messages";
        rs.Open( CRecordset::forwardOnly, rq);
        while(!rs.IsEOF())
        {
                rs.GetFieldValue("message",rq);
                rs.MoveNext();
        }
        rs.Close();
« Последнее редактирование: 30-03-2015 09:46 от Boriska » Записан
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #1 : 30-03-2015 09:42 » 

Сорри, никогда не занимался ни MFC, ни MySql, но вполне возможно, что не получается преобразовать из кодировки базы, в кодировку приложения. Можно попробовать добавить в начало программы установку локали, в соответствии с устновками ОС - setlocale(LC_ALL, ""), или если Вам всегда необходимо работать с cp1251, то, наверное, setlocale(LC_ALL, ".1251")
Записан
Sla
Команда клуба

ua
Offline Offline
Пол: Мужской

WWW
« Ответ #2 : 30-03-2015 12:09 » 

Конфликты
CHARACTER SET latin1 - это кодировка базы
CHARACTER SET cp1251 - это кодировка в таблице

Поэтому нужно установить кодировку для клиента.
SET NAMES 'cp1251'
SET CHARACTER SET 'cp1251'


Записан

Мы все учились понемногу... Чему-нибудь и как-нибудь.
Boriska
Помогающий

us
Offline Offline

« Ответ #3 : 31-03-2015 09:01 » 

Изменил и все равно

Код: (MySQL)
CREATE TABLE messages(
  id INT (11) NOT NULL AUTO_INCREMENT,
  message VARCHAR (100) NOT NULL,
  PRIMARY KEY (id)
)
ENGINE = INNODB
AUTO_INCREMENT = 1
CHARACTER SET cp1251
COLLATE cp1251_general_ci;
Записан
Boriska
Помогающий

us
Offline Offline

« Ответ #4 : 25-04-2018 12:42 » 

Вот тут много позже такая же проблема возникла в С#.
уже в С++ лезть некогда а здесь это решается установкой чарсета
в строке подключения ......charset=utf8;......
и все поехало.
Записан
RXL
Технический
Администратор

Online Online
Пол: Мужской

WWW
« Ответ #5 : 25-04-2018 19:57 » new

Есть разные способы, в зависимости от API и настроек окружения.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines