Ruslan Polupan
Ruslan PolupanJan. 9, 2018, 8:34 a.m.

Запрос к базе в отдельном потоке.

поток, запрос, модель

В связи с тем что запросы к базе выполняется достаточно долго (удаленные базы на объектах с низкой скоростью интернет соединения) запросы хочется выполнять в отдельных потоках.

Вопрос в следующем: Возможно ли получать из потока модель(QSqlQueryModel, QAbstractItemModel или какую либо другую).
Если нет, то каким образом лучше всего передавать результат работы запроса в основной поток для дальней шей обработки.
Данные нужны только для чтения.
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!

5
Evgenii Legotckoi
  • Jan. 9, 2018, 4:28 p.m.

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

В таком случае логичнее, чтобы у баз данных было некое API , через которое можно было бы получать интересующие данные в том же JSON формате через QNetworkAccessManager . Или это не представляется возможным?

    Ruslan Polupan
    • Jan. 10, 2018, 12:43 a.m.

    Баз много. но рабочей подключение одно (корректировка информации)

    Просто для создания скрипта корректировки нужно получить данные из 5-10 таблиц.
    Хотелось бы получить массив данных в отдельном потоке, затем передать его в главный и потом работать с ним.
    Вопрос в том в каком виде передать инфу из потока.

      Evgenii Legotckoi
      • Jan. 10, 2018, 2:30 a.m.

      Я бы тогда передал вектор некоторой информации, классов, которые будут отвечать за строки в таблице.


      class TableInfo
      {
      public:
          /* Секция геттеров и сеттеров */
        
      private:
          int m_id;
          int m_info_1;
          int m_info_2;
          QString m_description;  
      }
      В самом потоке информацию можно получить через QSqlQuery. Потом пройтись в цикле и подготовить вектор этих элементов
      QVector<TableInfo> infoVector;
      Сам вектор можно передавать через сигнал слотовое соединение, как сделано вот в этой статье про moveToThread . Думаю, что Вы её уже видели.

      Единственное, только нужно будет обезопаситься мьютексами во время передачи информации между потоками.
        Ruslan Polupan
        • Jan. 10, 2018, 7:57 a.m.

        Спасибо за "пинок" в нужном направлении. :-)

          Evgenii Legotckoi
          • Jan. 10, 2018, 8:01 a.m.

          Пожалуйста ))

            Comments

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

            C++ - Test 001. The first program and data types

            • Result:40points,
            • Rating points-8
            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
            Last comments
            ИМ
            Игорь МаксимовNov. 22, 2024, 10:51 p.m.
            Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
            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 аналогично. Могу предположить, что из-за более новой верси…
            Now discuss on the forum
            p
            pimacontrols85Dec. 31, 2024, 8:39 p.m.
            Finding the Right Rittal Small Enclosure for Your Needs Rittal is a leading manufacturer of enclosures for industrial and IT applications. Their small enclosures offer a compact and reliable solution for a wide range of needs, from housing electronic…
            Donald Randolph
            Donald RandolphDec. 30, 2024, 1:59 p.m.
            Personal Injury lawyer Santa Monica As an experienced Santa Monica personal injury lawyer, Donald C. Randolph has recovered over $100 Million in verdicts and settlements for our clients. In severe injury cases, this compensation i…
            Nirvana Yoga School
            Nirvana Yoga SchoolDec. 30, 2024, 4:13 p.m.
            OAuth2.0 через VK, получение email Nirvana Yoga School is one of the most trusted and reputed traditional Rishikesh yoga courses , India certified by Yoga Alliance, USA. We aim to spread traditional yoga teachings so t…
            s
            sriparkDec. 30, 2024, 3:47 p.m.
            Mobile app development company in Chennai A Mobile app development company in Chennai focuses on creating personalized mobile applications to meet various business requirements. These companies offer a full range of services,…
            a
            amit88Dec. 30, 2024, 3:45 p.m.
            Excel in Exams with PSLE Maths Tuition Singapore Preparing for the PSLE can be challenging, but the right guidance makes all the difference. PSLE Maths tuition Singapore offers personalized coaching to help students master key concepts, improv…

            Follow us in social networks