crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> Как создать пользовательский алиас ODBC под Windows
silver47
  опции профиля:
сообщение 26.4.2011, 6:46
Сообщение #1


Активный участник
***

Группа: Участник
Сообщений: 356
Регистрация: 1.4.2010
Пользователь №: 1584

Спасибо сказали: 40 раз(а)




Репутация:   6  


Доброго времени суток.

Может кто сталкивался, как создать на системе алиас ODBC для подключения к БД, если я знаю все необходимые данные, хост, порт, тип ДБ, имя пользователя, пароль.

Спасибо.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
Borodeys
  опции профиля:
сообщение 27.4.2011, 18:40
Сообщение #2


Студент
*

Группа: Участник
Сообщений: 23
Регистрация: 10.4.2011
Пользователь №: 2588

Спасибо сказали: 0 раз(а)




Репутация:   0  


Занимаюсь аналогичной проблемой уже длительное время. Подключение к БД осуществляется следующим образом
создаем файл connection.h:
#ifndef CONNECTION_H
#define CONNECTION_H

#include <QMessageBox>
#include <QSqlDatabase>
#include <QSqlError>
#include <QtSql>



static bool createConnection()
{
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.setDatabaseName("такая_то_база");
db.setUserName("логин_такой_то");
db.setPassword("пароль_эдакий");
bool connected = db.open();
if (!connected) {
QMessageBox::critical(0, ("connection.h "),"Cannot open database =[\n " +(db.lastError().text()), QMessageBox::Cancel);
return false;
}
}

#endif // CONNECTION_H

Затем из main.cpp обращаемся к данному заголовочному файлу:

#include <QtGui/QApplication>
#include "mainwindow.h"
#include "connection.h"

int main(int argc, char *argv[])
{
QApplication app(argc, argv);

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.driverName()="count";
app.addLibraryPath("pugins");
if (!createConnection()){
QMessageBox::critical(0, ("main.cpp"),"Cannot open database =[\n" +(db.lastError().text()), QMessageBox::Cancel);
return 1;
}

MainWindow w;
w.show();
return app.exec();
}

Затем, если у тебя window xp и MSSQL server, создаем драйвер подключения с именем нашей базы данных
Панель управления\ Администрирование\Источники данных (ODBC)\вкладка Системный DSN кнопочка добавить
Выбираем драйвер SQL Server Native Client и указываем его имя, как имя нашей базы данных.
Барабанная дробь........... Тада, теперь можно подключаться к ODBC базе данных.
Однако здесь только все начинается, по умолчанию QT использует только драйвера SQLite, а нам же нужен драйвер qsqlodbc4.dll и libqsqlodbc4.lib, которые лежат в папке qtdir\qt\plugins\sqldrivers.
Увы, как их подключить я не знаю, необходимо что-то прописать в .pro файле.
Если узнаешь как, обязательно напиши.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


7 чел. читают эту тему (гостей: 7, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 5.12.2024, 7:01