Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8627163
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 12, 20262026-06-12T08:12:29+00:00 2026-06-12T08:12:29+00:00

I would like to select only specific columns (ex. SELECT a FROM b ).

  • 0

I would like to select only specific columns (ex. SELECT a FROM b). I have a generic DAO and what I came up with is:

public List<T> getAll(boolean idAndVersionOnly) {
    CriteriaBuilder builder = manager.getCriteriaBuilder();
    CriteriaQuery<T> criteria = builder.createQuery(entityClazz);
    Root<T> root = criteria.from(entityClazz);
    if (idAndVersionOnly) {
        criteria.select(root.get("ID").get("VERSION")); // HERE IS ERROR
    } else {
        criteria.select(root);
    }
    return manager.createQuery(criteria).getResultList();
}

And the error is:
The method select(Selection<? extends T>) in the type CriteriaQuery<T> is not applicable for the arguments (Path<Object>). How should I change that? I want to get a type T object that has only ID and VERSION fields, and all others are null.

Type T extends AbstractEntity which has those 2 fields.

entityClazz is T.class.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-12T08:12:30+00:00Added an answer on June 12, 2026 at 8:12 am

    One of the JPA ways for getting only particular columns is to ask for a Tuple object.

    In your case you would need to write something like this:

    CriteriaQuery<Tuple> cq = builder.createTupleQuery();
    // write the Root, Path elements as usual
    Root<EntityClazz> root = cq.from(EntityClazz.class);
    cq.multiselect(root.get(EntityClazz_.ID), root.get(EntityClazz_.VERSION));  //using metamodel
    List<Tuple> tupleResult = em.createQuery(cq).getResultList();
    for (Tuple t : tupleResult) {
        Long id = (Long) t.get(0);
        Long version = (Long) t.get(1);
    }
    

    Another approach is possible if you have a class representing the result, like T in your case. T doesn’t need to be an Entity class. If T has a constructor like:

    public T(Long id, Long version)
    

    then you can use T directly in your CriteriaQuery constructor:

    CriteriaQuery<T> cq = builder.createQuery(T.class);
    // write the Root, Path elements as usual
    Root<EntityClazz> root = cq.from(EntityClazz.class);
    cq.multiselect(root.get(EntityClazz_.ID), root.get(EntityClazz_.VERSION));  //using metamodel
    List<T> result = em.createQuery(cq).getResultList();
    

    See this link for further reference.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

What I would like to do is select a specific set of rows from
I would like to select a field but only under specific circumstance, otherwise i
I would like to only insert a row, if the following SELECT returns a
I would like to run something like: select * from table where field in
I would like to select a row from the database based on two input
I would like to select a row from 2 different tables that are relational.
I would like to select all elements that have certain attribute or don't have
I would like my gridview to be filtered by the dropdown list I have.
I would like to use jqGrid for a great many grids that have only
I would like to select the XPath of a tag and the content of

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.