KL
Konstantin LazarevApril 17, 2017, 1:13 p.m.
SQL запросы
Подскажите пожалуйста. Есть бд с запросами, позициями сайта и датами. Мне необходимо выбрать все запросы и позиции к ним на протяжении 10 дней. Но время добавление некоторых запросов меньше чем 10 дней. В те дни, когда я не снимал данные, необходимо присвоить -, в остальные дни необходимо присвоить данные. На php я реализовал , образец http://gazetax.ru/HistoryPosition.php. Хочу написать на Qt модерацию данного приложения.
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
AD
- Akiv Doros
- Nov. 11, 2024, 2:58 p.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:50points,
- Rating points-4
m
- molni99
- Oct. 26, 2024, 1:37 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
m
- molni99
- Oct. 26, 2024, 1:29 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:20points,
- Rating points-10
Last comments
Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
Heap sorting algorithm The role of raloxifene in preventing breast cancer priligy precio
PyQt5 - Lesson 006. Work with QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
Now discuss on the forum
добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
IscanderCheOct. 31, 2024, 3:43 p.m.
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь МаксимовOct. 3, 2024, 4:05 a.m.
Нужен массив из 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 не выполняется.
Решил через костыль)