Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Some filters in QSqlTableModel and SQLite
Qt 6.11 is out! See what's new in the release blog

Some filters in QSqlTableModel and SQLite

Scheduled Pinned Locked Moved Solved General and Desktop
15 Posts 5 Posters 4.2k Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Mikeeeeee

    I understand this.
    How can I make few request?

    jsulmJ Offline
    jsulmJ Offline
    jsulm
    Lifetime Qt Champion
    wrote on last edited by
    #5

    @Mikeeeeee "I understand this." - then you should know how to do it.
    Like explained here https://www.w3schools.com/sql/sql_and_or.asp

    SearchTableModel->setFilter(" Age > 30 AND Age < 40");
    

    https://forum.qt.io/topic/113070/qt-code-of-conduct

    1 Reply Last reply
    1
    • M Offline
      M Offline
      Mikeeeeee
      wrote on last edited by Mikeeeeee
      #6

      I understand this.
      But I have many composite filters.
      I need to make many separated filters.

      jsulmJ JonBJ 2 Replies Last reply
      0
      • M Offline
        M Offline
        Mikeeeeee
        wrote on last edited by
        #7

        May be I ned to use temp table in SQLite?

        1 Reply Last reply
        0
        • M Mikeeeeee

          I understand this.
          But I have many composite filters.
          I need to make many separated filters.

          jsulmJ Offline
          jsulmJ Offline
          jsulm
          Lifetime Qt Champion
          wrote on last edited by
          #8

          @Mikeeeeee said in Some filters in QSqlTableModel and SQLite:

          composite filters

          Can you give an example?
          Why can't you do it like in my example?

          "May be I ned to use temp table in SQLite?" - maybe you could use SQL views?

          https://forum.qt.io/topic/113070/qt-code-of-conduct

          1 Reply Last reply
          0
          • M Mikeeeeee

            I understand this.
            But I have many composite filters.
            I need to make many separated filters.

            JonBJ Offline
            JonBJ Offline
            JonB
            wrote on last edited by
            #9

            @Mikeeeeee
            If you want several filters, you offer several filters to your user. If you want them them to be ANDed together, you build your SQL filter using AND between each one, like @jsulm said. It's your job to build up the necessary WHERE clause from whatever filtering you want. Does that answer your question?

            1 Reply Last reply
            0
            • M Offline
              M Offline
              Mikeeeeee
              wrote on last edited by
              #10

              It's not answer.
              Thea example of my filters:
              TableModel->setFilter("A1 = 30 AND A2 = 3 AND A3 = 7");
              TableModel->setFilter("A4 = 2 OR A5 = 2 OR A6 = 2");
              TableModel->setFilter("A7 = 3 OR A8 = 3 OR A8 = 3");
              TableModel->setFilter("A9 = 5 OR A10 = 5 OR A11 = 5");

              jsulmJ 1 Reply Last reply
              0
              • M Mikeeeeee

                It's not answer.
                Thea example of my filters:
                TableModel->setFilter("A1 = 30 AND A2 = 3 AND A3 = 7");
                TableModel->setFilter("A4 = 2 OR A5 = 2 OR A6 = 2");
                TableModel->setFilter("A7 = 3 OR A8 = 3 OR A8 = 3");
                TableModel->setFilter("A9 = 5 OR A10 = 5 OR A11 = 5");

                jsulmJ Offline
                jsulmJ Offline
                jsulm
                Lifetime Qt Champion
                wrote on last edited by
                #11

                @Mikeeeeee You can combine them into one

                https://forum.qt.io/topic/113070/qt-code-of-conduct

                1 Reply Last reply
                0
                • M Offline
                  M Offline
                  Mikeeeeee
                  wrote on last edited by
                  #12

                  This variant will be slowly.

                  Christian EhrlicherC jsulmJ 2 Replies Last reply
                  0
                  • M Mikeeeeee

                    This variant will be slowly.

                    Christian EhrlicherC Offline
                    Christian EhrlicherC Offline
                    Christian Ehrlicher
                    Lifetime Qt Champion
                    wrote on last edited by Christian Ehrlicher
                    #13

                    @Mikeeeeee said in Some filters in QSqlTableModel and SQLite:

                    This variant will be slowly.

                    Why should filtering by the database be slower than doing it in c++?

                    Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                    Visit the Qt Academy at https://academy.qt.io/catalog

                    1 Reply Last reply
                    3
                    • M Mikeeeeee

                      This variant will be slowly.

                      jsulmJ Offline
                      jsulmJ Offline
                      jsulm
                      Lifetime Qt Champion
                      wrote on last edited by
                      #14

                      @Mikeeeeee said in Some filters in QSqlTableModel and SQLite:

                      This variant will be slowly.

                      You measured it? Or how do you know it will be slow?
                      If you use SQL you should do the filtering in SQL, this is what SQL is for. And SQL server (and SQLite) can optimise SQL queries quite good. If you do the filtering in several steps in C++ this will happen: first you filter using one filter - a big amount of data will be loaded in your app (everything matching the first WHERE criteria), then you will apply second filter and so on. Doing complete filtering in SQL will be different: you will only load data in your app which matches all filters - way less memory consumption and faster operation.

                      https://forum.qt.io/topic/113070/qt-code-of-conduct

                      1 Reply Last reply
                      2
                      • M Offline
                        M Offline
                        Mikeeeeee
                        wrote on last edited by
                        #15

                        thank you

                        1 Reply Last reply
                        0

                        • Login

                        • Login or register to search.
                        • First post
                          Last post
                        0
                        • Categories
                        • Recent
                        • Tags
                        • Popular
                        • Users
                        • Groups
                        • Search
                        • Get Qt Extensions
                        • Unsolved