Russian Qt Forum
Май 18, 2012, 19:35
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
(Модератор:
Sergeich
) >
Как такое может быть?
Страниц: [
1
]
2
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Как такое может быть? (Прочитано 503 раз)
shame
Новичок
Offline
Сообщений: 17
Как такое может быть?
«
:
Декабрь 09, 2011, 14:43 »
Есть 2 программы, работающие с базой данных. 2 программа - это часть 1 выполненная в виде отдельной программы. Код идентичный (копипаст). Первая программа работает как надо, а во второй модель не может найти таблицу. Как такое может быть?
Записан
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 4122
Жаждущий знаний
Re: Как такое может быть?
«
Ответ #1 :
Декабрь 09, 2011, 14:52 »
По такому описанию можно только одно вответить - "Вот так".
Добавь конкретики.
Что за БД? Как подключаешься?
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
С уважением.
Пантер.
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #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
Сообщений: 4122
Жаждущий знаний
Re: Как такое может быть?
«
Ответ #3 :
Декабрь 09, 2011, 15:07 »
qDebug()<< model->lastError().text();
Что выводит на консоль?
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
С уважением.
Пантер.
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #4 :
Декабрь 09, 2011, 15:20 »
" Unable to find table in_stock"
Почему QSqlQuery видит таблицу, а модель нет. Я даже пробовал менять на QSqlTableModel. Результат тот же.
Записан
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 4122
Жаждущий знаний
Re: Как такое может быть?
«
Ответ #5 :
Декабрь 09, 2011, 15:30 »
Поищи по форуму, уже была когда-то такая проблема, но не помню, как решалось. Вроде, там с регистром что-то было.
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
С уважением.
Пантер.
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #6 :
Декабрь 09, 2011, 15:45 »
В поиске не нашел
везде постргес, а у меня скулайт. Щаз попробуй еще раз под вендой скомпилить, хотя и там не получалось.
Записан
Rem Norton
Самовар
Offline
Сообщений: 135
Re: Как такое может быть?
«
Ответ #7 :
Декабрь 09, 2011, 15:47 »
Выведи в консоль QStringList QSqlDatabase::tables ( QSql::TableType type = QSql::Tables ) const от своего подключения. Может и нет никакой "in_stock".
А вообще было бы не погано "всех посмотреть"
Записан
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #8 :
Декабрь 09, 2011, 15:50 »
Если бы не было, то каким образом вторая программа с аналогичным кодом работала? Тем более запрос ее видит, а модель нет. Чувствую щаз создам новый проект с другим названием и перенесу туда код.
Записан
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #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
Самовар
Offline
Сообщений: 135
Re: Как такое может быть?
«
Ответ #10 :
Декабрь 09, 2011, 17:15 »
Ошибка вот тут:
QSqlQuery *sq = new QSqlQuery();
Запрос не привязан к базе. Т.е. запрос в никуда.
Записан
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #11 :
Декабрь 09, 2011, 17:21 »
Ошибки здесь нету, так как берется подключение по-умолчанию. Перенес подключение к базе данных в конструктор и все стало работать. Только не пойму почему когда подключение было в main.cpp файле конструктор подключения не видел, а слоты видели?
Записан
Rem Norton
Самовар
Offline
Сообщений: 135
Re: Как такое может быть?
«
Ответ #12 :
Декабрь 09, 2011, 18:02 »
И все-таки: что такого военного в коде, что его нельзя показать целиком? Там что, пусковые коды межконтинентальных ракет???
Лечить геморой по фотографии - удел народных "целителей". Код в студию!
Записан
shame
Новичок
Offline
Сообщений: 17
Re: Как такое может быть?
«
Ответ #13 :
Декабрь 09, 2011, 19:47 »
Та ничего там нету такого, не выкладывал только потому что этот код в любых примерах есть. Сделал соединение к базе данных, создаю модель, которая не видит это соединение. Если так уже хотите то выложу вам весь проект.
Записан
ultimatet41
Новичок
Offline
Сообщений: 6
Re: Как такое может быть?
«
Ответ #14 :
Декабрь 09, 2011, 19:53 »
Попробуйте перенесите код подключения к базе данных в функцию main().
«
Последнее редактирование: Декабрь 09, 2011, 20:52 от ultimatet41
»
Записан
Страниц: [
1
]
2
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
=> Архив
===> Программирование
=====> Python
===> Веб программирование
=====> PHP, PERL, CGI
Загружается...