URL: https://www.opennet.me/cgi-bin/openforum/vsluhboard.cgi
Форум: vsluhforumID9
Нить номер: 3601
[ Назад ]

Исходное сообщение
"обращение к базам mysql и Oracle"

Отправлено tl , 16-Ноя-04 22:50 
Господа, посоветуйте ,pls!
пишу многопотоковый демон, необходимо уметь посылать SQL запросы
mysql и Oracle,
чем лучше возпользоваться для
обращения к базам: unixODBC, каким-нибудь dbconnect, чем-то еще?
или использовать отдельно myODBC и что-нить для Oracle ?

демон должен быть надежным(быстродействие потом)

интересно узнать ваш личный опыт...
Спасибо.


Содержание

Сообщения в этом обсуждении
"обращение к базам mysql и Oracle"
Отправлено Dead Mustdie , 18-Ноя-04 09:54 
Про mysql ничего не скажу, ибо не пользовался никогда.

Что касается ORACLE, то личный опыт подсказывает использовать
напрямую вызовы OCI. Дабы сократить писанину, имеет
смысл над ними соорудить небольшую custom-надстройку.

Почему не советую использовать готовые надстройки?
unixODBC штука в целом неплохая и довольно надёжная,
но весьма ограниченная по возможностям (записать либо
прочитать с её помощью BLOB-поле я так и не сумел -
допускаю, впрочем, в данном случае проблемы с
/dev/hands ;-) ). А что касается прочих творений,
то здесь играют два фактора:

- при наложении глюков frontend'а на глюки собственно
ORACLE начинаются такие чудеса, что только держись. А
frontend приемлемой надёжности я видел ровно один - unixODBC.

-  в Ораклячем саппорте часто работают редкие сволочи,
и если к ним приходит customer, использующий для доступа к
сервисам их продукта стороннюю прослойку, все баги и проблемы
они скопом, не разбираясь, валят на оную стороннюю прослойку.
Единственный шанс их дожать - притащить им *маленький*
кусок реального *своего* кода, обращающегося к СУБД
через OCI. Тут уж им просто деваться некуда.

Есть некая "родная" (самим Ораклом сделанная) надстройка над
OCI в виде набора C++-классов. Я не пользовался; может, оно
и ничего.


"обращение к базам mysql и Oracle"
Отправлено tl , 18-Ноя-04 11:37 
Спасибо,
а кто-нибудь пользовался OTL(otl.sourceforge.net)?