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. MySQL problem with inserting quote in my QSqlQuery prepare statement
Forum Updated to NodeBB v4.3 + New Features

MySQL problem with inserting quote in my QSqlQuery prepare statement

Scheduled Pinned Locked Moved Solved General and Desktop
qsqlqueryqstringquotes
20 Posts 4 Posters 2.8k Views
  • 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.
  • S swankster

    @Ronel_qtmaster
    "SELECT * FROM schema.table WHERE MATCH( phrase ) AGAINST( '":phrase"' IN BOOLEAN MODE)" );
    qry.bindValue( ":phrase", phrase_var );

    executedQuery() returns
    SELECT * FROM language.master WHERE MATCH(phrase) AGAINST( '":phrase"' IN BOOLEAN MODE)"

    what i need to see in my executequery is
    SELECT * FROM schema.table WHERE MATCH(text) AGAINST( '"this is my phrase"' IN BOOLEAN MODE)"
    how can I display '"this is my phrase"' without " appearing?

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

    @swankster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

    "SELECT * FROM schema.table WHERE MATCH( phrase ) AGAINST( '":phrase"' IN BOOLEAN MODE)" );

    If you used the forum's Code (</> button) wehere you are asking about quote characters we could see you are using

    "SELECT * FROM schema.table WHERE MATCH( phrase ) AGAINST( '":phrase"' IN BOOLEAN MODE)" );
    

    So instead of '":phrase"' have you tried ':phrase', ":phrase" or :phrase?

    S 1 Reply Last reply
    0
    • JonBJ JonB

      @swankster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

      yes, i have used bind as well with the exact same results.

      You have never told us of any "results". Don't know what your actual issue is. Maybe someone else does, but I cannot tell from what you have written. You could show error messages/results but you do not.

      And SQL is a general language so why would MYSQL plugin not accept this syntax?

      Because I have used MySQL and other SQLs for a long time and have never come across

      MATCH(phrase) AGAINST( '"this is my phrase"' IN BOOLEAN MODE);

      If you think this statement is somehow in "general SQL" it is not. Each SQL has its own various additions to "standard" SQL (whatever that is), and this would have to fall into that category. I don't know if MySQL has such a clause, and if what OP has written is syntactically correct. That is all I said.

      S Offline
      S Offline
      swankster
      wrote on last edited by
      #12

      @JonB
      syntax works perfectly while in workbench. as stated initial post.

      the output string is also stated from executedQuery where i am receiving a '"\phrase"' instead of '"phrase"'

      JonBJ 1 Reply Last reply
      0
      • S swankster

        @JonB
        syntax works perfectly while in workbench. as stated initial post.

        the output string is also stated from executedQuery where i am receiving a '"\phrase"' instead of '"phrase"'

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

        @swankster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

        syntax works perfectly while in workbench. as stated initial post.

        But from workbench you are not using bound variables, are you? Or are you?
        And your first post does not use bound variables, does it?
        And you still have not said or shown what error you get where in SQL code?
        Trying to help, but not seeming to get anywhere.

        the output string is also stated from executedQuery where i am receiving a '"\phrase"' instead of '"phrase"'

        Copy and paste error messages please. The characters here are vital and I do not think as you have written. And please post inside Code tags, you are asking question about punctuation characters which we cannot even read right!

        AGAINST( '":phrase"' IN BOOLEAN MODE)"

        This does not look right.

        the output string is also stated from executedQuery where i am receiving a '"\phrase"' instead of '"phrase"'

        Already said: qDebug() or debugger may show literal characters like ' or " inside strings with backslashes.

        1 Reply Last reply
        0
        • S swankster

          @Ronel_qtmaster
          "SELECT * FROM schema.table WHERE MATCH( phrase ) AGAINST( '":phrase"' IN BOOLEAN MODE)" );
          qry.bindValue( ":phrase", phrase_var );

          executedQuery() returns
          SELECT * FROM language.master WHERE MATCH(phrase) AGAINST( '":phrase"' IN BOOLEAN MODE)"

          what i need to see in my executequery is
          SELECT * FROM schema.table WHERE MATCH(text) AGAINST( '"this is my phrase"' IN BOOLEAN MODE)"
          how can I display '"this is my phrase"' without " appearing?

          Ronel_qtmasterR Offline
          Ronel_qtmasterR Offline
          Ronel_qtmaster
          wrote on last edited by
          #14

          @swankster Why do you want to display it without appearing first? Qt has its syntax

          1 Reply Last reply
          0
          • JonBJ JonB

            @swankster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

            "SELECT * FROM schema.table WHERE MATCH( phrase ) AGAINST( '":phrase"' IN BOOLEAN MODE)" );

            If you used the forum's Code (</> button) wehere you are asking about quote characters we could see you are using

            "SELECT * FROM schema.table WHERE MATCH( phrase ) AGAINST( '":phrase"' IN BOOLEAN MODE)" );
            

            So instead of '":phrase"' have you tried ':phrase', ":phrase" or :phrase?

            S Offline
            S Offline
            swankster
            wrote on last edited by
            #15

            @JonB
            yes, i have tried ':phrase', ":phrase" and :phrase
            ':phrase' returns ':phrase'
            :phrase returns ?
            it acts as though binding does not work with AGAINST()

            in workbench, correct I am not using bound value. that is what im attempting to send to MySQL. it is somewhat working in that it will match any of the words within the phrase to the field. But I need this to check for exact phrase. if it exists to prompt the user that the particular phase is already set in the DB. if it does not exist it automatically tries to add. but the field is unique so it does error when attempting to create it as new if it already exists.

            The WHERE MATCH AGAINST() does works in workbench with the exact phrase.

            JonBJ Ronel_qtmasterR 2 Replies Last reply
            0
            • S swankster

              @JonB
              yes, i have tried ':phrase', ":phrase" and :phrase
              ':phrase' returns ':phrase'
              :phrase returns ?
              it acts as though binding does not work with AGAINST()

              in workbench, correct I am not using bound value. that is what im attempting to send to MySQL. it is somewhat working in that it will match any of the words within the phrase to the field. But I need this to check for exact phrase. if it exists to prompt the user that the particular phase is already set in the DB. if it does not exist it automatically tries to add. but the field is unique so it does error when attempting to create it as new if it already exists.

              The WHERE MATCH AGAINST() does works in workbench with the exact phrase.

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

              @swankster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

              it acts as though binding does not work with AGAINST()

              Which is what I suggested might well be the case right from the start.......

              @JonB said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

              @Ronel_qtmaster
              Do you have any evidence that bindValue() will be accepted by the MySQL driver for this MATCH ... AGAINST clause? Unless you have tried it you would not know (and I do not, but it would not surprise me if not). For example, LIKE and IN do not accept binds (as far as I recall).

              I did not think he should suggest that to you unless he has tested it actually worked. See the earlier discussion. So unless you know the MySQL driver accepts binding for this clause do not use binding!

              Binding is accepted, or not accepted, by the driver on a case by case basis. It is not just a "macro substitution".

              1 Reply Last reply
              0
              • S swankster

                @JonB
                yes, i have tried ':phrase', ":phrase" and :phrase
                ':phrase' returns ':phrase'
                :phrase returns ?
                it acts as though binding does not work with AGAINST()

                in workbench, correct I am not using bound value. that is what im attempting to send to MySQL. it is somewhat working in that it will match any of the words within the phrase to the field. But I need this to check for exact phrase. if it exists to prompt the user that the particular phase is already set in the DB. if it does not exist it automatically tries to add. but the field is unique so it does error when attempting to create it as new if it already exists.

                The WHERE MATCH AGAINST() does works in workbench with the exact phrase.

                Ronel_qtmasterR Offline
                Ronel_qtmasterR Offline
                Ronel_qtmaster
                wrote on last edited by
                #17

                @swankster I would suggest you to try a simple binding syntax with Mysql and see which result you receive.So a statement different that what you want to achieve.If you have a positive result, then binding is working and your syntax is wrong.If not..

                JonBJ 1 Reply Last reply
                0
                • Ronel_qtmasterR Ronel_qtmaster

                  @swankster I would suggest you to try a simple binding syntax with Mysql and see which result you receive.So a statement different that what you want to achieve.If you have a positive result, then binding is working and your syntax is wrong.If not..

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

                  @Ronel_qtmaster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

                  and your syntax is wrong.If not..

                  Sorry, but this is not necessarily correct, and you are repeating (what I believe to be) the same mistake as before, in advising the OP to use binding when you have no evidence that this SQL clause, even if correct, accepts parameter binding. You seem to think that anything which is syntactically correct can have bindings put into it, and that is not the case. Please read my earlier posts.

                  @swankster
                  Good luck if you can get binding to work for your MATCH ... AGAINST, I suspect you will not. Assuming that is the case, you just need to generate the correct literal sting which you have tested in workshop into C++ code. Qt's QString::arg() is a convenient way to generate QStrings which require C++ variables' values (your phrase_var) inserted into them.

                  S 1 Reply Last reply
                  0
                  • JonBJ JonB

                    @Ronel_qtmaster said in MySQL problem with inserting quote in my QSqlQuery prepare statement:

                    and your syntax is wrong.If not..

                    Sorry, but this is not necessarily correct, and you are repeating (what I believe to be) the same mistake as before, in advising the OP to use binding when you have no evidence that this SQL clause, even if correct, accepts parameter binding. You seem to think that anything which is syntactically correct can have bindings put into it, and that is not the case. Please read my earlier posts.

                    @swankster
                    Good luck if you can get binding to work for your MATCH ... AGAINST, I suspect you will not. Assuming that is the case, you just need to generate the correct literal sting which you have tested in workshop into C++ code. Qt's QString::arg() is a convenient way to generate QStrings which require C++ variables' values (your phrase_var) inserted into them.

                    S Offline
                    S Offline
                    swankster
                    wrote on last edited by
                    #19

                    @JonB
                    binding does not work with Against. looks like I will need to do a different approach. Thanks

                    JonBJ 1 Reply Last reply
                    0
                    • S swankster

                      @JonB
                      binding does not work with Against. looks like I will need to do a different approach. Thanks

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

                      @swankster
                      :) Like I said, just build the (correct, including whatever quoting, and if you are OK on possible SQL injection attacks!) string and pass that without using binding, for this query.

                      1 Reply Last reply
                      0
                      • S swankster has marked this topic as solved on

                      • Login

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