Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

MySQL 5 + ADO + Builder 6. Проблема с русским языком.

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
stormbringer_222



Зарегистрирован: 15.02.2006
Сообщения: 4

СообщениеДобавлено: Ср Фев 15 2006 09:10    Заголовок сообщения: MySQL 5 + ADO + Builder 6. Проблема с русским языком. Ответить с цитатой

MySQL 5 + ADO + Builder 6. Проблема с русским языком.
Суть проблемы в следующем:

создал к примеру хранимую процедурку:
DELIMITER $$

DROP PROCEDURE IF EXISTS `schedule`.`viewtest` $$
CREATE PROCEDURE `viewtest`(IN param VARCHAR(50))
BEGIN
insert into test (name) values (param);
END $$

DELIMITER ;

она просто вставляет передаваемое значение в таблицу test
открываю MySQL Query Browser и пишу:
CALL viewtest('COOL')
все заи..ца!
далее пишу CALL viewtest('получилось')
все нормально...
теперь пробую из билдера:
ADOQuery1->Close();
ADOQuery1->SQL->Text="CALL viewtest('"+Edit1->Text+"')";
ADOQuery1->ExecSQL();
все работает нормально.... но... без русских букв...
то есть, если в поле Edit1 написать "test" - все нармально,
а если "проверка" - борода... мдя... короче ошибочка "[MySQL][ODBC 3.51 Driver][mysqld-5.0.16-nt]Data too long for column 'name' at row 1."
я так понимаю тут проблема в кодировках (вначале MySQL Query Browser ни в какую не хотел принимать русский, но после того как я поменял в свойствах поля charset на cp1251 он заработал)
вообщем, помогите кто может!!!
P.S. с третьей версией MySQL таких проблем не было.... вот так вот...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
beliy



Зарегистрирован: 10.12.2004
Сообщения: 124
Откуда: Москва

СообщениеДобавлено: Ср Фев 15 2006 10:01    Заголовок сообщения: Ответить с цитатой

да есть некий косяк.. для версий 4.1 и выше можно использовать
Код:
set names cp1251

перед выполнением любых запросов, тогда нормально должно работать
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
stormbringer_222



Зарегистрирован: 15.02.2006
Сообщения: 4

СообщениеДобавлено: Ср Фев 15 2006 16:40    Заголовок сообщения: Ответить с цитатой

beliy писал(а):
да есть некий косяк.. для версий 4.1 и выше можно использовать
Код:
set names cp1251

перед выполнением любых запросов, тогда нормально должно работать

УРА!!!! ЗАРАБОТАЛО!!! beliy, СПАСИБО ТЕБЕ ОГРОМНОЕ!!! я реально из-за этого косяка весь день на работе убил Sad
правда, сначала я не догнал... и стал писать так:
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("SET NAMES cp1251");
ADOQuery1->SQL->Add("SELECT * FROM tab");
ADOQuery1->Open();
но была ошибка... ";" после cp1251 тоже не помогла...
и тут до меня дошло... Smile и я написал так:

ADOQuery1->Close();
ADOQuery1->SQL->Text = "SET NAMES cp1251";
ADOQuery1->ExecSQL(); // выполняем...

// после этого и выборка и вставка корректно работают... все счастливы и довольны! Smile

ADOQuery1->Close();
ADOQuery1->SQL->Text = "SELECT * FROM mydb.tab";
ADOQuery1->Open();

ADOQuery1->Close();
ADOQuery1->SQL->Text = "insert into tab (Name) values ('"+Edit1->Text+"')";
ADOQuery1->ExecSQL();
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Dimasm



Зарегистрирован: 25.04.2005
Сообщения: 454

СообщениеДобавлено: Вт Апр 11 2006 19:42    Заголовок сообщения: Re: MySQL 5 + ADO + Builder 6. Проблема с русским языком. Ответить с цитатой

stormbringer_222 писал(а):

....
создал к примеру хранимую процедурку:
DELIMITER $$

DROP PROCEDURE IF EXISTS `schedule`.`viewtest` $$
CREATE PROCEDURE `viewtest`(IN param VARCHAR(50))
BEGIN
insert into test (name) values (param);
END $$

DELIMITER ;
....


Это, а как ты создал в MySQL хранимую процедуру?
приведённый тобой код не прокатывает (таблички другие подставлял)
Я где-то читал, что MySQL не поддерживает хранимых процедур
Расскажи как делал и где можно про сие прочитать Question
_________________
С уважением Dimasm
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
stormbringer_222



Зарегистрирован: 15.02.2006
Сообщения: 4

СообщениеДобавлено: Ср Апр 12 2006 11:22    Заголовок сообщения: Ответить с цитатой

Все просто... качай с официального сайта MySQL 5 версии, mysql administrator и mysql query browser... Действительно, раньше MySQL хранимые процедуры не поддерживала... Но теперь начиная с 5ой версии это положение изменилось. В MySQL Query Browser можно без проблем создать БД, табличку, хранимую процедуру и т.д. Причем при создании ХП, создается шаблон, в который вписываешь код. А вообще при установки 5ой версии ставится help, в нем все описано...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Dimasm



Зарегистрирован: 25.04.2005
Сообщения: 454

СообщениеДобавлено: Ср Апр 12 2006 18:44    Заголовок сообщения: Ответить с цитатой

дык, и вправду Surprised
Думаю к 6-й версии долже появиться контроль целостности и триггеры Smile
_________________
С уважением Dimasm
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...