Russian Qt Forum
Ноябрь 27, 2024, 19:02 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1] 2   Вниз
  Печать  
Автор Тема: Как такое может быть?  (Прочитано 8691 раз)
shame
Гость
« : Декабрь 09, 2011, 14:43 »

Есть 2 программы, работающие с базой данных. 2 программа - это часть 1 выполненная в виде отдельной программы. Код идентичный (копипаст). Первая программа работает как надо, а во второй модель не может найти таблицу. Как такое может быть?
Записан
Пантер
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 5876


Жаждущий знаний


Просмотр профиля WWW
« Ответ #1 : Декабрь 09, 2011, 14:52 »

По такому описанию можно только одно вответить - "Вот так".
Добавь конкретики.
Что за БД? Как подключаешься?
Записан

1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
shame
Гость
« Ответ #2 : Декабрь 09, 2011, 14:57 »

Код:
model = new QSqlRelationalTableModel(this);
    model->setTable("in_stock");
    model->setSort(1,Qt::AscendingOrder);
    model->select();
    qDebug()<< model->lastError().text();
    while(model->canFetchMore()) model->fetchMore();
    ui->tovarBox->setModel(model);

Идентично в обоих программах. Соединение с базой есть, так как поиск с использованием
Код:
QSqlQuery *sq = new QSqlQuery();
        sq->exec("SELECT name FROM in_stock WHERE kod = " + QString::number(kod));
работает.

Если нада, могу выложить как делаю соединение, но думаю дело не в нем. Тем более в первой программе все работает и моделька видит таблицу.
Записан
Пантер
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 5876


Жаждущий знаний


Просмотр профиля WWW
« Ответ #3 : Декабрь 09, 2011, 15:07 »

qDebug()<< model->lastError().text();
Что выводит на консоль?
Записан

1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
shame
Гость
« Ответ #4 : Декабрь 09, 2011, 15:20 »

" Unable to find table in_stock"

Почему QSqlQuery видит таблицу, а модель нет. Я даже пробовал менять на QSqlTableModel. Результат тот же.
Записан
Пантер
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 5876


Жаждущий знаний


Просмотр профиля WWW
« Ответ #5 : Декабрь 09, 2011, 15:30 »

Поищи по форуму, уже была когда-то такая проблема, но не помню, как решалось. Вроде, там с регистром что-то было.
Записан

1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
shame
Гость
« Ответ #6 : Декабрь 09, 2011, 15:45 »

В поиске не нашел    Грустный везде постргес, а у меня скулайт. Щаз попробуй еще раз под вендой скомпилить, хотя и там не получалось.
Записан
Rem Norton
Гость
« Ответ #7 : Декабрь 09, 2011, 15:47 »

Выведи в консоль QStringList QSqlDatabase::tables ( QSql::TableType type = QSql::Tables ) const от своего подключения. Может и нет никакой "in_stock".

А вообще было бы не погано "всех посмотреть"  Смеющийся
Записан
shame
Гость
« Ответ #8 : Декабрь 09, 2011, 15:50 »

Если бы не было, то каким образом вторая программа с аналогичным кодом работала? Тем более запрос ее видит, а модель нет. Чувствую щаз создам новый проект с другим названием и перенесу туда код.
Записан
shame
Гость
« Ответ #9 : Декабрь 09, 2011, 16:50 »

Добавил
Код:
QSqlQuery *sq = new QSqlQuery();
    sq->exec("SELECT name FROM in_stock");
    sq->next();
    qDebug() << sq->value(0).toString();
мне выдало: QSqlQuery::exec: database not open

Хотя тоже самое, но запущенное в слоте по нажатию кнопки, возвращает результат. Почему в конструкторе он игнорирует моё соединение с базой?

PS: перенес создание модели в слот с поиском. при нажатии кнопки вызвался слот и комбобокс заполнился.
« Последнее редактирование: Декабрь 09, 2011, 16:54 от shame » Записан
Rem Norton
Гость
« Ответ #10 : Декабрь 09, 2011, 17:15 »

Ошибка вот тут:

QSqlQuery *sq = new QSqlQuery();

Запрос не привязан к базе. Т.е. запрос в никуда.
Записан
shame
Гость
« Ответ #11 : Декабрь 09, 2011, 17:21 »

Ошибки здесь нету, так как берется подключение по-умолчанию. Перенес подключение к базе данных в конструктор и все стало работать. Только не пойму почему когда подключение было в main.cpp файле конструктор подключения не видел, а слоты видели?
Записан
Rem Norton
Гость
« Ответ #12 : Декабрь 09, 2011, 18:02 »

И все-таки: что такого военного в коде, что его нельзя показать целиком? Там что, пусковые коды межконтинентальных ракет???
Лечить геморой по фотографии - удел народных "целителей".  Код в студию!  Смеющийся
Записан
shame
Гость
« Ответ #13 : Декабрь 09, 2011, 19:47 »

Та ничего там нету такого, не выкладывал только потому что этот код в любых примерах есть. Сделал соединение к базе данных, создаю модель, которая не видит это соединение. Если так уже хотите то выложу вам весь проект.
Записан
ultimatet41
Гость
« Ответ #14 : Декабрь 09, 2011, 19:53 »

Попробуйте перенесите код подключения к базе данных в функцию main().
« Последнее редактирование: Декабрь 09, 2011, 20:52 от ultimatet41 » Записан
Страниц: [1] 2   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.05 секунд. Запросов: 23.