How to create a db neutral orderby returned data in active-objects

I have an AO entity with lifecycle info like 'created' (Timestamp type) and a data entity that extends it. I want to use AO to retrieve the data entities, ordered with most recent dates first. If I try the following:

Query query=Query.select().order("created");
MyObj[] = aoService.find(MyObj.class,query);

I get: ERROR: column "created" does not exist Position: 58 at org.apache.velocity.runtime.parser.node.ASTMethod.execute(ASTMethod.java:251)

But, the table does have a Timestamp column, A bug possibly? Even if this worked, Im curious how I would indicate 'ascending' or 'descending' orders.

Anyone got an example to hand?

Rgds

2 answers

1 accepted

0 votes
Accepted answer

It looks like a case sensitivity issue to me. Some database are case sensitive, Postgres being one of them. And all table and column names converted by the AO plugin are upper case.

See the table names and column names conventions for more information.

In your case I think simply changing your code to the following should work.

Query.select().order("CREATED")

Hi Sam, I should have thought of that, upper casing worked. If AO coverts all columns to upper case, it would be a wrinkle removed if column operations shouldnt be case sensitive?

0 votes

Andy, you should be able to do

Query.select().order("created asc") 
Query.select().order("created desc")

Try it, if that's not working then there may be a bug

Hi James,

Thanks for that, looks like the fundamental problem is the inheritance, logged as https://studio.atlassian.com/browse/AO-295

Suggest an answer

Log in or Sign up to answer
Community showcase
Published Thursday in Agile

How Scrum works? It starts with training and education

To answer “How scrum works,” most of the teams I've worked with first addressed the question: “where to start?”  That question applies to both implementation and improvements on the Scrum framew...

184 views 3 5
Read article

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you