KL
Konstantin LazarevApril 17, 2017, 1:13 p.m.

SQL запросы

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

We recommend hosting TIMEWEB
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!

9
KL
  • April 17, 2017, 1:16 p.m.

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

    Evgenii Legotckoi
    • April 18, 2017, 12:59 a.m.

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

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

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

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

      KL
      • April 18, 2017, 2:29 a.m.

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

        KL
        • April 18, 2017, 3:15 a.m.

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

          Evgenii Legotckoi
          • April 18, 2017, 8:25 a.m.
          • The answer was marked as a solution.

          Запрос выглядит как обычный 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
            • April 18, 2017, 8:48 a.m.

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

              KL
              • April 23, 2017, 5:40 a.m.

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

                KL
                • April 23, 2017, 5:46 a.m.
                  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
                  • April 23, 2017, 5:48 a.m.

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

                    Comments

                    Only authorized users can post comments.
                    Please, Log in or Sign up
                    AD

                    C ++ - Test 004. Pointers, Arrays and Loops

                    • Result:50points,
                    • Rating points-4
                    m

                    C ++ - Test 004. Pointers, Arrays and Loops

                    • Result:80points,
                    • Rating points4
                    m

                    C ++ - Test 004. Pointers, Arrays and Loops

                    • Result:20points,
                    • Rating points-10
                    Last comments
                    Evgenii Legotckoi
                    Evgenii LegotckoiNov. 1, 2024, 12:37 a.m.
                    Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                    A
                    ALO1ZEOct. 19, 2024, 6:19 p.m.
                    Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь МаксимовOct. 5, 2024, 5:51 p.m.
                    Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas5July 5, 2024, 9:02 p.m.
                    QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    k
                    kmssrFeb. 9, 2024, 5:43 a.m.
                    Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                    Now discuss on the forum
                    Evgenii Legotckoi
                    Evgenii LegotckoiJune 25, 2024, 1:11 a.m.
                    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                    t
                    tonypeachey1Nov. 15, 2024, 5:04 p.m.
                    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                    NSProject
                    NSProjectJune 4, 2022, 1:49 p.m.
                    Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                    9
                    9AnonimOct. 25, 2024, 7:10 p.m.
                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                    Follow us in social networks