Russian Qt Forum
Ноябрь 23, 2024, 20:59
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
QTableview
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: QTableview (Прочитано 5071 раз)
NIKA
Гость
QTableview
«
:
Сентябрь 06, 2012, 09:50 »
Всем привет!В Qt новичок. Вот появился вопрос-как мне по имеющемуся номеру участка num вытащить его id из базы?
Записан
mutineer
Гость
Re: QTableview
«
Ответ #1 :
Сентябрь 06, 2012, 09:57 »
Вероятно при помощи SQL-запроса и класса QSqlQuery
Записан
NIKA
Гость
Re: QTableview
«
Ответ #2 :
Сентябрь 06, 2012, 10:58 »
int id = "SELECT id FROM amnu WHERE num"=+num, где num получаю int num =ui->amnuPropertiesTableView->model()->data(indexcolumn).toInt(); Не хочет работать.Что-то с синтаксисом наверное. Посмотрите, пожалуйста!
Записан
mutineer
Гость
Re: QTableview
«
Ответ #3 :
Сентябрь 06, 2012, 10:59 »
ага, синтаксис совсем не похож на C++ - инту присваивать строку это как-то странно
Записан
NIKA
Гость
Re: QTableview
«
Ответ #4 :
Сентябрь 06, 2012, 11:01 »
int num = ui->amnuPropertiesTableView->model()->data(indexcolumn).toInt();
QString string = QVariant(num).toString();
qDebug()<<string;
QString sqlFilter;
sqlFilter = "SELECT id FROM amnu WHERE num ="+string;
qDebug возвращает "458"
"SELECT id FROM amnu WHERE num =458" сам номер а не его Id
Записан
mutineer
Гость
Re: QTableview
«
Ответ #5 :
Сентябрь 06, 2012, 11:03 »
А что еще ты ожидал видеть в qDebug(), если ты в него выводишь значение num? SQL-запрос составленный надо еще выполнить. Читай доку по QSqlQuery
Записан
NIKA
Гость
Re: QTableview
«
Ответ #6 :
Сентябрь 06, 2012, 11:06 »
Спасибо!
Записан
NIKA
Гость
Re: QTableview
«
Ответ #7 :
Сентябрь 06, 2012, 11:21 »
Сделала так и все равно id выводит 0, но qDebug()<<query.exec(sqlFilter) равно true.Посмотрите, пожалуйста в чем ошибка, все утро уже парюсь.
QString string = QVariant(num).toString();
QSqlQuery query;
QString sqlFilter;
sqlFilter = "SELECT id FROM amnu WHERE num ="+string;
if (!query.exec(sqlFilter))
{
qDebug() << "Cannot open database:" << query.lastError();
};
qDebug()<<query.exec(sqlFilter);
int id = QVariant(sqlFilter).toInt();
qDebug()<<id;
Записан
mutineer
Гость
Re: QTableview
«
Ответ #8 :
Сентябрь 06, 2012, 11:24 »
QVariant(sqlFilter).toInt(); - вот это строчка берет строку "SELECT id FROM amnu WHERE num =" и переводит в int. глупость. читай доку
Ну и два раза выполнять запрос бессмысленно
Записан
NIKA
Гость
Re: QTableview
«
Ответ #9 :
Сентябрь 06, 2012, 11:34 »
Я так понимаю, что запрос выполнился и теперь мне это значение надо получить. Но как, что то я не нашла. Next что ли?Подскажи, пожалуйста.
Записан
mutineer
Гость
Re: QTableview
«
Ответ #10 :
Сентябрь 06, 2012, 11:35 »
В доке написано доходчиво и есть примеры
Записан
NIKA
Гость
Re: QTableview
«
Ответ #11 :
Сентябрь 06, 2012, 11:46 »
Все, получилось!
Спасибо большое за подсказки!!!
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...