KL
Konstantin Lazarev17 квітня 2017 р. 13:13
SQL запросы
Подскажите пожалуйста. Есть бд с запросами, позициями сайта и датами. Мне необходимо выбрать все запросы и позиции к ним на протяжении 10 дней. Но время добавление некоторых запросов меньше чем 10 дней. В те дни, когда я не снимал данные, необходимо присвоить -, в остальные дни необходимо присвоить данные. На php я реализовал , образец http://gazetax.ru/HistoryPosition.php. Хочу написать на Qt модерацию данного приложения.
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 12 листопада 2024 р. 01:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 11:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 11:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 22:51
Evgenii Legotckoi01 листопада 2024 р. 00:37
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 17:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi25 червня 2024 р. 01:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 17:04
NSProject04 червня 2022 р. 13:49
IscanderChe01 листопада 2024 р. 01:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Нужен массив из 10 чисел, позиций сайта. Где данные не отслеживались присвоить "-"
Могу пока только направление подсказать, куда копать. Поскольку это задача достаточно объёмная.
Для такой таблицы нужно будет писать собственную модель данных, которая будет забирать данные из БД сырым запросом, а потом заполнять вектор записей. Для записей стоит предусмотреть некую структуру или класс, который будет хранить необходимые параметры.
Когда забрали данные сырым запросом, проходите в цикле все полученные данные по датам, там где данных нет, вставляете пустую запись, там где есть данные, вставляете заполненную запись. А отдавать все эти данные следует через соответствующий метод модели (имею ввиду метода data ). Чтобы получить данный метод, нужно наследоваться от одной из моделей данных. Я мог бы предложить QSqlQueryModel, но думаю что даже эта модель здесь не совсем подойдёт. Нужно наследоваться от QAbstractItemModel и реализовывать весь необходимый функционал по работе с базой данных.
Такие сложности здесь возникают из-за того, что модели данных Qt, которые работают с SQL не поддерживают наличие пустых строк в связи с тем, что логика заполнения пустыми строками может быть очень разнообразной, поэтому это следует реализовывать самому программисту.
Как выглядит запрос SQL, который достает одну строку. Например по точной дате. Не через while, а на прямую в массив. 1 запрос = 1 строка. После чего, я оформлю это через for. И какой ответ возвращает бд в случае отсутствия искомого результата.
Через addDay к дате хочу реализовать. В цикле for будет изменяться дата.
Запрос выглядит как обычный SQL запрос:
Вот только QSqlQuery не имеет такого метода, который вернёт сразу результат, всё равно придётся использовать while цикл, чтобы перебрать все необходимые строчки. Метода exec() возвращает true если сам запрос прошёл успешно и false в противном случае. Но он вернёт результат true , даже если не нашлось ни одной строки.
В принципе, забрать одну строку можно так:
Вообще, я бы взял сразу диапазон за месяц и сразу прошёлся бы по каждой дате, а если даты нет, то заполнял бы TableView пустыми строками или колонками пока не натолкнулся бы на запись с датой, которая равна проверяемой дате. Что-то вроде такого:
Тут немного псевдокода, нет времени подробный пример писать, но думаю, что идея будет понятна.
Благодарю, думаю разберусь, спасибо!
При отсутствии ответа базы данных не переходит на цикл while. Если query.next()==0 цикл while не выполняется.
Решил через костыль)