Kuzmich
Гость
|
|
« : 26-11-2003 09:13 » |
|
Вот, решил занятся MySQL... С базой работаю через ODBC, но у меня появляется ошибка "Драйвер ODBC не поддерживает динамических подмножеств данных", можно конечно сделать snapshot вместо dynaset, но меня это не устраивает. Может я драйвер не тот использую. Причем тот же самый код в Access'е работает нормально. Помогите пожалуйста (драйвер где взять нормальный), либо я чето нетак делаю, в общем любая умная мысль приветствуется плюсами.
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #1 : 26-11-2003 09:24 » |
|
Дело не в драйвере, а в самом MySQL. В ней многое, что есть в коммерческих базах, не реализованно. Уточнить что есть, а чего нет можно на http://www.mysql.com . Как я понимаю, "dynaset" - это другое название курсоров. Этого пока нет. Если объяснишь в чем их особенная польза, то я попробую объяснить как работать без них.
|
|
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Kuzmich
Гость
|
|
« Ответ #2 : 26-11-2003 10:28 » |
|
Дело не в драйвере, а в самом MySQL. да скорее всего в драйвере, или в моих кривых руках Как я понимаю, "dynaset" - это другое название курсоров. Этого пока нет. Если объяснишь в чем их особенная польза, то я попробую объяснить как работать без них. VC предоставляет два метода работы с БД: snapshot - снимки, загружает все данные из таблицы в память, потом операции производятся над данными в памяти, по окончании работы возвращаются обратно в базу, если за это время данные в базе поменял кто-то другой, будет крестец. dynaset - динамические множества, работает с данными в "on-line режиме" Просто для работы с БД в VC есть класс CRecordset, я пользую его, в API копаться неохота.[/quote]
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #3 : 26-11-2003 11:28 » |
|
Нет такого в MySQL и на драйвер грешить не надо. Все эти сервисные штучки ведут к потери производительности и достаточно сложны в реализации, потому они только в планах на реализацию в будующих версиях MySQL...
API у MySQL очень простое и долго "разбираться" там не придется. Я бы сказал элементарное. И опять же скорость работы повышается, чем через прослойку ODBC работать.
Для контроля за изменением можно применять следующие приемы: 1) при коротких транзакциях (SELECT, изменение и сразу UPDATE) можно делать блокировку таблиц или строк (поддержка этого зависит от типа базы). 2) при большом времени между SELECT и UPDATE: зависит от правил совместной работы с таблицами. Можно переодически перечитывать на предмет оновлений, можно проверять на обновление перед UPDATE (чтобы чужии изменения не затереть). Вариантов много.
Кстати, надеюсь, MySQL используется не как excel, простой набор табличек, которые целиком скачиваются для местной работы?
|
|
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Kuzmich
Гость
|
|
« Ответ #4 : 28-11-2003 06:14 » |
|
скачал с mysql.com последнюю версию драйвера ODBC, dynaset'ы он тоже не держит. Мне нужен совет как работать с БД(mysql, interbase) из MSVC ?. На данный момент есть несколько вариантов: 1. использовать ODBC через snapshot'ы 2. использовать DAO 3. использовать OLE DB 4. напрямую работать с базой вот незнаю что лучше и не потеряет актуальность со временем зы. заранее спасибо.
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #5 : 28-11-2003 08:54 » |
|
Из задачи надо исходить - опиши ее.
|
|
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Kuzmich
Гость
|
|
« Ответ #6 : 28-11-2003 10:29 » |
|
Из задачи надо исходить - опиши ее. Да нету пока задачи, просто тренируюсь.... RXL расскажи пожалуйста про API MySQL
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #7 : 28-11-2003 11:15 » |
|
Опишу в кратце API для С. Есть несколько типов: MYSQL - handle соединения, MYSQL_RES - handle для результирующего набора (result), MYSQL_ROW - " This is a safe-type representation of one row of data." (по сути, char**) - используется при выборке строки из MYSQL_RES, MYSQL_FIELD - описание одного поля в MYSQL_RES, и еще нескольких редко употребимых. Небольшой примерчик: #include <stdio.h> #include <mysql/mysql.h>
void print_error(MYSQL *con) { printf("ERROR: mysql_real_query(): #%u ($s)\n",mysql_errno(con),mysql_errstr(con)); }
int main() { MYSQL *con; MYSQL_RES *res; MYSQL_ROW row; char *q="SHOW TABLES"; int rows,cols,i;
con=mysql_init(0); if(!mysql_real_connect(con,"localhost","user","pass","test_db",0,0,0)) print_error(con); else if(!mysql_real_query(con,q,strlen(q))) { if(res=mysql_store_result(con)) { rows=mysql_num_rows(res); cols=mysql_num_fields(res); printf("Fetched %u rows by %u fields\n",rows,cols); while(row=mysql_fetch_row(res) { for(i=0;i<cols;i++) printf("| $s |",row[i]); printf("\n"); } mysql_free_result(res); } else printf("Returns a zero set\n"); } else print_error(con); mysql_close(con); return 0; }
Подробное описание ф-ий есть на английском в мануале на их сайте и на русском на http://www.mysql.ru/docs/ (несколько устаревший мануал, но вполне годный).
|
|
« Последнее редактирование: 22-11-2007 15:55 от Алексей1153++ »
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Kuzmich
Гость
|
|
« Ответ #8 : 28-11-2003 13:04 » |
|
скачал я mysql++, вроде все просто и красиво там у них, при компиляции выдает 13 варнингов вида: c:\program files\microsoft visual studio\vc98\mysql\include\type_info1.hh(172) : warning C4800: 'int' : forcing value to bool 'true' or 'false' (performance warning) незнаю как лечить #include <mysql/mysql.h> такой хедер есть в mysql++, но в таком виде ошибки пишет нехарошие
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #9 : 28-11-2003 13:42 » |
|
Ну, что писать в include, зависит от того, где у тебя заголовки и какие пути для поиска переданы компилятору. К тому же я писал о С, а не о С++. Для С++ смотри в том же мануале.
|
|
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Kuzmich
Гость
|
|
« Ответ #10 : 02-12-2003 11:45 » |
|
Хех, заголовочные файлы, либы и дллки нашлись в дистрибе MySQL, чета я их сразу незаметил Там действительно чистый С и все предельно ясно, вот только я нелюбитель садо-мазы, поэтому всетаки расковырял ODBC. Есть 2 преимущества: 1. Не надо кодить в чистом С или даже С++, в MFC есть готовые классы для работы. 2. Появилась идея приложения работающего по желанию юзера как клиент-сервер, либо файл-сервер. Для осуществления не надо переделывать ни байта кода, просто изменить настройки ODBC. MySQL действительно не работает с dynaset'ами, причем и Interbase тоже, как я понял это только фича мелкомяхтовских продуктов Access, MS SQL Server. Сделал доступ через snapshot'ы, все оказалось просто. Есть правда один минус, все данные хранятся в памяти (не проверял, где-то прочитал). ЗЫ. Искренне завидую 2м нашим делфистам, которым достаточно просто подключить компонент, а на сам механизм глубоко наплевать.
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #11 : 02-12-2003 12:41 » |
|
Был опыт использования MySQL через ODBC в VisualFoxPro (программировал не я - я советы давал и сервером управлял). Негативный момент: при длительном (практически постоянном) соединении, если соединение с сервером прерывается (в моих испытаниях - посредством таймаута на сервере), то соединение не востонавливается автоматом. В С-API это возможно через mysql_ping().
Что касается места хранения результирующего набора, то есть два метода: скачивается полностью к клиенту, или находится на сервере и скачивается по мере необходимости (построчно или больше - не знаю). Метод можно выбрать в настройках DSN.
|
|
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Mr. MO
Гость
|
|
« Ответ #12 : 09-12-2003 20:30 » |
|
Имея небольшой опыт прогшраммирования MySQL хотелось бы порекомендовать использовать API MySQL, а не ODBC. Он действительно несложный, и позволяет гибче работать с базой, чем громоздкий ODBC. Кстати читал я где- то, как чуваки сами проводили независимые тесты и выяснилось, что производительность при использовании ODBC драйвера падает процентов на 30 - 35.
|
|
|
Записан
|
|
|
|
|
Kuzmich
Гость
|
|
« Ответ #14 : 10-12-2003 04:18 » |
|
Лучше всего из VC подойтет MySQL++ (классы для работы с базой) или же MySQL API (просто функции). у меня этот mysql++ выдает 13 варнингов при компиляции
|
|
|
Записан
|
|
|
|
|
Kuzmich
Гость
|
|
« Ответ #16 : 10-12-2003 11:13 » |
|
но ведь программа то работает
работает, но у меня все-таки в последнее время пропала склонность к мазахизму, классы MFC использовать куда удобнее 8)
|
|
|
Записан
|
|
|
|
Mr. MO
Гость
|
|
« Ответ #17 : 10-12-2003 14:15 » |
|
у меня этот mysql++ выдает 13 варнингов при компиляции
А что за варнинги???
|
|
|
Записан
|
|
|
|
Kuzmich
Гость
|
|
« Ответ #18 : 11-12-2003 04:02 » |
|
c:\program files\microsoft visual studio\vc98\mysql++\include\type_info1.hh(159) : warning C4800: 'unsigned int' : forcing value to bool 'true' or 'false' (performance warning) все в таком духе с номером C4800
|
|
|
Записан
|
|
|
|
RXL
|
|
« Ответ #19 : 11-12-2003 08:42 » |
|
Пустяковая ошибка. Самый простой способ борьбы - отключить часть предупреждений.
|
|
|
Записан
|
... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
|
|
|
Kuzmich
Гость
|
|
« Ответ #20 : 11-12-2003 12:55 » |
|
Я пробовал ставить warning level: none, не помогло, м.б. где-то в другом месте отключить ?
|
|
|
Записан
|
|
|
|
|