crossplatform.ru

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

mezmay
  опции профиля:
сообщение 29.11.2012, 8:55
Сообщение #1


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

Группа: Участник
Сообщений: 272
Регистрация: 13.7.2009
Из: Ростов-на-Дону
Пользователь №: 904

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




Репутация:   1  


Работа с одной базой данных будет происходить из разных потоков. В документации сказано, что в этом случае надо для каждого потока создавать(или открывать?) соединение с БД. Как это правильно сделать? Для одного потока соединение создается так:
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("XXX");
    db.setUserName("Admin"); 
    db.setHostName("localhost"); 
    db.setPassword("Admin"); 
    db.open();

я должен этот код вызвать для каждого потока, или какой-то другой? Там еще сказано:
Цитата
Adds a database to the list of database connections using the driver type and the connection name connectionName. If there already exists a database connection called connectionName, that connection is removed.

Это значит, что для каждого потока надо в addDatabase() передавать еще и новое имя коннекта?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
maint
  опции профиля:
сообщение 29.11.2012, 9:41
Сообщение #2


Участник
**

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

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




Репутация:   2  


я что то недопонял, а зачем вообще в sqlite юзер и пароль ?
Для отдельных dll/so я поступаю достаточно просто
    if(QSqlDatabase::contains(QSqlDatabase::defaultConnection)) {
           db = QSqlDatabase::database();
       } else {
           db = QSqlDatabase::addDatabase("QSQLITE");
    }
    db.setDatabaseName(dbname);
    db.open();

Иначе про default connection что то говорит на консоль
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

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


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


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


RSS Рейтинг@Mail.ru Текстовая версия Сейчас: 15.6.2025, 18:59