KL
Konstantin LazarevСәуір 17, 2017, 1:13 Т.Қ.

SQL запросы

Подскажите пожалуйста. Есть бд с запросами, позициями сайта и датами. Мне необходимо выбрать все запросы и позиции к ним на протяжении 10 дней. Но время добавление некоторых запросов меньше чем 10 дней. В те дни, когда я не снимал данные, необходимо присвоить -, в остальные дни необходимо присвоить данные. На php я реализовал , образец http://gazetax.ru/HistoryPosition.php. Хочу написать на Qt модерацию данного приложения.

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

9
KL
  • Сәуір 17, 2017, 1:16 Т.Қ.

Нужен массив из 10 чисел, позиций сайта. Где данные не отслеживались присвоить "-"

    Evgenii Legotckoi
    • Сәуір 18, 2017, 12:59 Т.Ж.

    Могу пока только направление подсказать, куда копать. Поскольку это задача достаточно объёмная.

    Для такой таблицы нужно будет писать собственную модель данных, которая будет забирать данные из БД сырым запросом, а потом заполнять вектор записей. Для записей стоит предусмотреть некую структуру или класс, который будет хранить необходимые параметры.

    Когда забрали данные сырым запросом, проходите в цикле все полученные данные по датам, там где данных нет, вставляете пустую запись, там где есть данные, вставляете заполненную запись. А отдавать все эти данные следует через соответствующий метод модели (имею ввиду метода data ). Чтобы получить данный метод, нужно наследоваться от одной из моделей данных. Я мог бы предложить QSqlQueryModel, но думаю что даже эта модель здесь не совсем подойдёт. Нужно наследоваться от QAbstractItemModel и реализовывать весь необходимый функционал по работе с базой данных.

    Такие сложности здесь возникают из-за того, что модели данных Qt, которые работают с SQL не поддерживают наличие пустых строк в связи с тем, что логика заполнения пустыми строками может быть очень разнообразной, поэтому это следует реализовывать самому программисту.

      KL
      • Сәуір 18, 2017, 2:29 Т.Ж.

      Как выглядит запрос SQL, который достает одну строку. Например по точной дате. Не через while, а на прямую в массив. 1 запрос = 1 строка. После чего, я оформлю это через for. И какой ответ возвращает бд в случае отсутствия искомого результата.

        KL
        • Сәуір 18, 2017, 3:15 Т.Ж.

        Через addDay к дате хочу реализовать. В цикле for будет изменяться дата.

          Evgenii Legotckoi
          • Сәуір 18, 2017, 8:25 Т.Ж.
          • Жауап шешім ретінде белгіленді.

          Запрос выглядит как обычный SQL запрос:

          SELECT * FROM table WHERE datetime='datetime_value';

          Вот только QSqlQuery не имеет такого метода, который вернёт сразу результат, всё равно придётся использовать while цикл, чтобы перебрать все необходимые строчки. Метода exec() возвращает true если сам запрос прошёл успешно и false в противном случае. Но он вернёт результат true , даже если не нашлось ни одной строки.

          В принципе, забрать одну строку можно так:

          QSqlQuery query;
          query.exec("SELECT * FROM table WHERE datetime='datetime_value';)");
          while (query.next()) {
              QDateTime name = query.value(0).toDateTime();
              break;  // То есть сразу выскочить из цикла при первом же полученном значении.
          }
          

          Вообще, я бы взял сразу диапазон за месяц и сразу прошёлся бы по каждой дате, а если даты нет, то заполнял бы TableView пустыми строками или колонками пока не натолкнулся бы на запись с датой, которая равна проверяемой дате. Что-то вроде такого:

          QSqlQuery query;
          query.exec("SELECT * FROM table WHERE date BETWEEN date1 AND date2;)");
          QDate currentDate = 'Условно 1-е число месяца';
          while (query.next()) {
              while (true)
              {
                  if (query.value(0).toDate() != currentDate)
                  {
                      tableView->addEmptyRow();
                      currentDate++; // увеличить на одно число
                  }
                  else
                  {
                      break;    
                  }
              }
              tableView->addRowWithData(query.value(0).toDateTime());
          }

          Тут немного псевдокода, нет времени подробный пример писать, но думаю, что идея будет понятна.

            KL
            • Сәуір 18, 2017, 8:48 Т.Ж.

            Благодарю, думаю разберусь, спасибо!

              KL
              • Сәуір 23, 2017, 5:40 Т.Ж.

              При отсутствии ответа базы данных не переходит на цикл while. Если query.next()==0 цикл while не выполняется.

                KL
                • Сәуір 23, 2017, 5:46 Т.Ж.
                  QList<int> List;
                    int a;
                   for(int i=0; i<10; i++)
                   {
                       int check=0;
                       QString date;
                       QDate dateToday;
                      date=dateToday.currentDate().addDays(-10+i).toString("yyyy/MM/dd");
                    QSqlQuery query(DB);
                  query.exec("SELECT google_position FROM history_query WHERE query='"+Query+"' AND date='"+date+"'");
                    while(query.next())
                    {
                        a=query.value(0).toInt();
                        List.push_back(a);
                        check=1;
                    }
                    if(check!=1)
                    {
                        qDebug()<<"Good";
                        List.push_back(-1);
                    }
                   }
                  KL
                  • Сәуір 23, 2017, 5:48 Т.Ж.

                  Решил через костыль)

                    Пікірлер

                    Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                    Кіріңіз немесе Тіркеліңіз
                    Г

                    C++ - Тест 001. Первая программа и типы данных

                    • Нәтиже:66ұпай,
                    • Бағалау ұпайлары-1
                    t

                    C++ - Тест 001. Первая программа и типы данных

                    • Нәтиже:33ұпай,
                    • Бағалау ұпайлары-10
                    t

                    Qt - Тест 001. Сигналы и слоты

                    • Нәтиже:52ұпай,
                    • Бағалау ұпайлары-4
                    Соңғы пікірлер
                    G
                    GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
                    Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
                    d
                    dblas5Шілде 5, 2024, 11:02 Т.Ж.
                    QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    k
                    kmssrАқп. 8, 2024, 6:43 Т.Қ.
                    Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                    АК
                    Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
                    Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                    Енді форумда талқылаңыз
                    Evgenii Legotckoi
                    Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
                    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                    F
                    FynjyШілде 22, 2024, 4:15 Т.Ж.
                    при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
                    BlinCT
                    BlinCTМаусым 25, 2024, 1 Т.Ж.
                    Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
                    BlinCT
                    BlinCTМамыр 5, 2024, 5:46 Т.Ж.
                    Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
                    Evgenii Legotckoi
                    Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
                    Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

                    Бізді әлеуметтік желілерде бақылаңыз