KL
Konstantin Lazarev17 апреля 2017 г. 23:13

SQL запросы

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

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

Вам это нравится? Поделитесь в социальных сетях!

9
KL
  • 17 апреля 2017 г. 23:16

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

    Evgenii Legotckoi
    • 18 апреля 2017 г. 10:59

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

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

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

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

      KL
      • 18 апреля 2017 г. 12:29

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

        KL
        • 18 апреля 2017 г. 13:15

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

          Evgenii Legotckoi
          • 18 апреля 2017 г. 18: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 г. 18:48

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

              KL
              • 23 апреля 2017 г. 15:40

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

                KL
                • 23 апреля 2017 г. 15: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 г. 15:48

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

                    Комментарии

                    Только авторизованные пользователи могут публиковать комментарии.
                    Пожалуйста, авторизуйтесь или зарегистрируйтесь
                    Ua

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

                    • Результат:84баллов,
                    • Очки рейтинга4
                    Ua

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

                    • Результат:42баллов,
                    • Очки рейтинга-8
                    ОК

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

                    • Результат:47баллов,
                    • Очки рейтинга-6
                    Последние комментарии
                    ИМ
                    Игорь Максимов22 ноября 2024 г. 21:51
                    Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                    Evgenii Legotckoi
                    Evgenii Legotckoi31 октября 2024 г. 23:37
                    Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                    A
                    ALO1ZE19 октября 2024 г. 17:19
                    Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь Максимов5 октября 2024 г. 16:51
                    Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas55 июля 2024 г. 20:02
                    QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    Сейчас обсуждают на форуме
                    f
                    firstlunoxod15 февраля 2025 г. 13:46
                    Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
                    Дмитрий
                    Дмитрий3 февраля 2025 г. 16:24
                    Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                    NW
                    Nayo Wai30 января 2025 г. 19:22
                    не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                    n
                    nkly3 января 2025 г. 12:52
                    Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                    M
                    Marsel17 августа 2023 г. 0:26
                    OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

                    Следите за нами в социальных сетях