aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Moger <james.moger@gitblit.com>2016-04-04 19:32:44 -0400
committerJames Moger <james.moger@gitblit.com>2016-04-04 19:32:44 -0400
commit2523ad5454716a9e08f0d3220a92760aa50773e2 (patch)
tree71a5404dfdaadcef114fa27ebc47b7023b371f3f
parent27979f07905dbf95b478a48babc99643d71bfdec (diff)
downloadiciql-2523ad5454716a9e08f0d3220a92760aa50773e2.tar.gz
iciql-2523ad5454716a9e08f0d3220a92760aa50773e2.zip
Fixes #21: Order by descending on primitives
-rw-r--r--releases.moxie1
-rw-r--r--src/main/java/com/iciql/Query.java32
-rw-r--r--src/test/java/com/iciql/test/ModelsTest.java2
-rw-r--r--src/test/java/com/iciql/test/PrimitivesTest.java5
4 files changed, 36 insertions, 4 deletions
diff --git a/releases.moxie b/releases.moxie
index 6a448cb..3630f1d 100644
--- a/releases.moxie
+++ b/releases.moxie
@@ -10,6 +10,7 @@ r30: {
text: ~
security: ~
fixes:
+ - Fixed order by descending on primitives (issue-21)
- Fixed setting null column values (issue-22)
- Fixed Postgres 9.5 Upsert syntax (issue-23)
changes: ~
diff --git a/src/main/java/com/iciql/Query.java b/src/main/java/com/iciql/Query.java
index f8fd4ca..7a8a1ff 100644
--- a/src/main/java/com/iciql/Query.java
+++ b/src/main/java/com/iciql/Query.java
@@ -736,6 +736,38 @@ public class Query<T> {
return this;
}
+ public Query<T> orderByDesc(byte field) {
+ return orderByDescPrimitive(field);
+ }
+
+ public Query<T> orderByDesc(short field) {
+ return orderByDescPrimitive(field);
+ }
+
+ public Query<T> orderByDesc(int field) {
+ return orderByDescPrimitive(field);
+ }
+
+ public Query<T> orderByDesc(long field) {
+ return orderByDescPrimitive(field);
+ }
+
+ public Query<T> orderByDesc(float field) {
+ return orderByDescPrimitive(field);
+ }
+
+ public Query<T> orderByDesc(double field) {
+ return orderByDescPrimitive(field);
+ }
+
+ Query<T> orderByDescPrimitive(Object field) {
+ Object alias = getPrimitiveAliasByValue(field);
+ if (alias == null) {
+ return orderByDesc(field);
+ }
+ return orderByDesc(alias);
+ }
+
public Query<T> orderByDesc(Object expr) {
OrderExpression<T> e = new OrderExpression<T>(this, expr, true, false, false);
addOrderBy(e);
diff --git a/src/test/java/com/iciql/test/ModelsTest.java b/src/test/java/com/iciql/test/ModelsTest.java
index a5474df..4230f4e 100644
--- a/src/test/java/com/iciql/test/ModelsTest.java
+++ b/src/test/java/com/iciql/test/ModelsTest.java
@@ -173,6 +173,6 @@ public class ModelsTest {
.orderByDesc(SupportedTypes.SAMPLE.id)
.selectDistinct(SupportedTypes.SAMPLE.id);
assertEquals(10, ids.size());
- assertEquals("[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]", ids.toString());
+ assertEquals("[10, 9, 8, 7, 6, 5, 4, 3, 2, 1]", ids.toString());
}
}
diff --git a/src/test/java/com/iciql/test/PrimitivesTest.java b/src/test/java/com/iciql/test/PrimitivesTest.java
index 938fd32..6250649 100644
--- a/src/test/java/com/iciql/test/PrimitivesTest.java
+++ b/src/test/java/com/iciql/test/PrimitivesTest.java
@@ -106,14 +106,13 @@ public class PrimitivesTest {
// insert random models in reverse order
List<PrimitivesModel> models = PrimitivesModel.getList();
- PrimitivesModel model = models.get(0);
Collections.reverse(models);
// insert them in reverse order
db.insertAll(models);
PrimitivesModel p = new PrimitivesModel();
- List<Long> list = db.from(p)/*.orderByDesc(p.myLong)*/.select(p.myLong);
+ List<Long> list = db.from(p).orderByDesc(p.myLong).select(p.myLong);
assertEquals(models.size(), list.size());
- assertEquals("[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]", list.toString());
+ assertEquals("[10, 9, 8, 7, 6, 5, 4, 3, 2, 1]", list.toString());
}
}