Getting an error while using “Generics” in Hibernate Query












0















I'm using Hibernate in my project and using "Query" Like below.



Query query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


I'm getting the result. When i'm using generics Like below



Query<?> query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


getting the result because "?" is something as wildcard (or) it will accept any datatype



when i'm using the code as below getting some error( java.lang.IllegalArgumentException: Update/delete queries cannot be typed ). i'm using Integer datatype because createQuery return number when it's executed



Query<Integer> query = em.createQuery("delete from User where name=:name", Integer.class);
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


Any suggestions. I have to use Generics with specific datatype in it like above code.



thanks in advance










share|improve this question

























  • What error are you getting?

    – Eamon Scullion
    Nov 13 '18 at 16:40











  • java.lang.IllegalArgumentException: Update/delete queries cannot be typed

    – vikram kumar
    Nov 14 '18 at 4:28
















0















I'm using Hibernate in my project and using "Query" Like below.



Query query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


I'm getting the result. When i'm using generics Like below



Query<?> query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


getting the result because "?" is something as wildcard (or) it will accept any datatype



when i'm using the code as below getting some error( java.lang.IllegalArgumentException: Update/delete queries cannot be typed ). i'm using Integer datatype because createQuery return number when it's executed



Query<Integer> query = em.createQuery("delete from User where name=:name", Integer.class);
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


Any suggestions. I have to use Generics with specific datatype in it like above code.



thanks in advance










share|improve this question

























  • What error are you getting?

    – Eamon Scullion
    Nov 13 '18 at 16:40











  • java.lang.IllegalArgumentException: Update/delete queries cannot be typed

    – vikram kumar
    Nov 14 '18 at 4:28














0












0








0








I'm using Hibernate in my project and using "Query" Like below.



Query query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


I'm getting the result. When i'm using generics Like below



Query<?> query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


getting the result because "?" is something as wildcard (or) it will accept any datatype



when i'm using the code as below getting some error( java.lang.IllegalArgumentException: Update/delete queries cannot be typed ). i'm using Integer datatype because createQuery return number when it's executed



Query<Integer> query = em.createQuery("delete from User where name=:name", Integer.class);
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


Any suggestions. I have to use Generics with specific datatype in it like above code.



thanks in advance










share|improve this question
















I'm using Hibernate in my project and using "Query" Like below.



Query query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


I'm getting the result. When i'm using generics Like below



Query<?> query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


getting the result because "?" is something as wildcard (or) it will accept any datatype



when i'm using the code as below getting some error( java.lang.IllegalArgumentException: Update/delete queries cannot be typed ). i'm using Integer datatype because createQuery return number when it's executed



Query<Integer> query = em.createQuery("delete from User where name=:name", Integer.class);
query.setParameter("name", "Zigi");
int deleted = query.executeUpdate();


Any suggestions. I have to use Generics with specific datatype in it like above code.



thanks in advance







java hibernate






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 14 '18 at 4:28







vikram kumar

















asked Nov 13 '18 at 16:35









vikram kumarvikram kumar

115




115













  • What error are you getting?

    – Eamon Scullion
    Nov 13 '18 at 16:40











  • java.lang.IllegalArgumentException: Update/delete queries cannot be typed

    – vikram kumar
    Nov 14 '18 at 4:28



















  • What error are you getting?

    – Eamon Scullion
    Nov 13 '18 at 16:40











  • java.lang.IllegalArgumentException: Update/delete queries cannot be typed

    – vikram kumar
    Nov 14 '18 at 4:28

















What error are you getting?

– Eamon Scullion
Nov 13 '18 at 16:40





What error are you getting?

– Eamon Scullion
Nov 13 '18 at 16:40













java.lang.IllegalArgumentException: Update/delete queries cannot be typed

– vikram kumar
Nov 14 '18 at 4:28





java.lang.IllegalArgumentException: Update/delete queries cannot be typed

– vikram kumar
Nov 14 '18 at 4:28












1 Answer
1






active

oldest

votes


















0














Unfortunately executeUpdate does not allow you to use a typed query.



Instead you can use uniqueResult, and cast to the type that you want:



Query query = em.createQuery("delete from User where name=:name");
query.setParameter("name", "Zigi");
int deleted = (Integer) query.uniqueResult();


Referencing this answer






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53285557%2fgetting-an-error-while-using-generics-in-hibernate-query%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    Unfortunately executeUpdate does not allow you to use a typed query.



    Instead you can use uniqueResult, and cast to the type that you want:



    Query query = em.createQuery("delete from User where name=:name");
    query.setParameter("name", "Zigi");
    int deleted = (Integer) query.uniqueResult();


    Referencing this answer






    share|improve this answer




























      0














      Unfortunately executeUpdate does not allow you to use a typed query.



      Instead you can use uniqueResult, and cast to the type that you want:



      Query query = em.createQuery("delete from User where name=:name");
      query.setParameter("name", "Zigi");
      int deleted = (Integer) query.uniqueResult();


      Referencing this answer






      share|improve this answer


























        0












        0








        0







        Unfortunately executeUpdate does not allow you to use a typed query.



        Instead you can use uniqueResult, and cast to the type that you want:



        Query query = em.createQuery("delete from User where name=:name");
        query.setParameter("name", "Zigi");
        int deleted = (Integer) query.uniqueResult();


        Referencing this answer






        share|improve this answer













        Unfortunately executeUpdate does not allow you to use a typed query.



        Instead you can use uniqueResult, and cast to the type that you want:



        Query query = em.createQuery("delete from User where name=:name");
        query.setParameter("name", "Zigi");
        int deleted = (Integer) query.uniqueResult();


        Referencing this answer







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 14 '18 at 10:12









        Eamon ScullionEamon Scullion

        682313




        682313






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53285557%2fgetting-an-error-while-using-generics-in-hibernate-query%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            List item for chat from Array inside array React Native

            Thiostrepton

            Caerphilly