use of com.querydsl.core.Tuple in project querydsl by querydsl.
the class UnionBase method union5.
// FIXME for CUBRID
// Teradata: The ORDER BY clause must contain only integer constants.
@SuppressWarnings("unchecked")
@Test
@ExcludeIn({ DERBY, CUBRID, FIREBIRD, TERADATA })
// FIXME
@Ignore
public void union5() {
/* (select e.ID, e.FIRSTNAME, superior.ID as sup_id, superior.FIRSTNAME as sup_name
* from EMPLOYEE e join EMPLOYEE superior on e.SUPERIOR_ID = superior.ID)
* union
* (select e.ID, e.FIRSTNAME, null, null from EMPLOYEE e)
* order by ID asc
*/
QEmployee superior = new QEmployee("superior");
SubQueryExpression<Tuple> sq1 = query().from(employee).join(employee.superiorIdKey, superior).select(employee.id, employee.firstname, superior.id.as("sup_id"), superior.firstname.as("sup_name"));
SubQueryExpression<Tuple> sq2 = query().from(employee).select(employee.id, employee.firstname, null, null);
List<Tuple> results = query().union(sq1, sq2).orderBy(employee.id.asc()).fetch();
for (Tuple result : results) {
System.err.println(Collections.singletonList(result));
}
}
use of com.querydsl.core.Tuple in project querydsl by querydsl.
the class SelectWindowFunctionsBase method windowFunctions_manual_paging.
@Test
public void windowFunctions_manual_paging() {
Expression<Long> rowNumber = SQLExpressions.rowNumber().over().orderBy(employee.lastname.asc()).as("rn");
Expression<Object[]> all = Wildcard.all;
// simple
System.out.println("#1");
for (Tuple row : query().from(employee).select(employee.firstname, employee.lastname, rowNumber).fetch()) {
System.out.println(row);
}
System.out.println();
// with subquery, generic alias
System.out.println("#2");
SQLQuery<Tuple> sub = query().from(employee).select(employee.firstname, employee.lastname, rowNumber);
SimplePath<Tuple> subAlias = Expressions.path(Tuple.class, "s");
for (Object[] row : query().from(sub.as(subAlias)).select(all).fetch()) {
System.out.println(Arrays.asList(row));
}
System.out.println();
// with subquery, only row number
System.out.println("#3");
SQLQuery<Long> sub2 = query().from(employee).select(rowNumber);
SimplePath<Long> subAlias2 = Expressions.path(Long.class, "s");
for (Object[] row : query().from(sub2.as(subAlias2)).select(all).fetch()) {
System.out.println(Arrays.asList(row));
}
System.out.println();
// with subquery, specific alias
System.out.println("#4");
SQLQuery<Tuple> sub3 = query().from(employee).select(employee.firstname, employee.lastname, rowNumber);
for (Tuple row : query().from(sub3.as(employee2)).select(employee2.firstname, employee2.lastname).fetch()) {
System.out.println(Collections.singletonList(row));
}
}
use of com.querydsl.core.Tuple in project querydsl by querydsl.
the class GroupByIterateTest method map3.
@Test
public void map3() {
CloseableIterator<Map<Integer, Map<Integer, String>>> results = MAP3_RESULTS.transform(groupBy(postId).iterate(map(postId, map(commentId, commentText))));
List<Map<Integer, Map<Integer, String>>> actual = IteratorAdapter.asList(results);
Object postId = null;
Map<Integer, Map<Integer, String>> posts = null;
List<Map<Integer, Map<Integer, String>>> expected = new LinkedList<Map<Integer, Map<Integer, String>>>();
for (Iterator<Tuple> iterator = MAP3_RESULTS.iterate(); iterator.hasNext(); ) {
Tuple tuple = iterator.next();
Object[] array = tuple.toArray();
if (posts == null || !(postId == array[0] || postId != null && postId.equals(array[0]))) {
posts = new LinkedHashMap<Integer, Map<Integer, String>>();
expected.add(posts);
}
postId = array[0];
@SuppressWarnings("unchecked") Pair<Integer, Pair<Integer, String>> pair = (Pair<Integer, Pair<Integer, String>>) array[1];
Integer first = pair.getFirst();
Map<Integer, String> comments = posts.computeIfAbsent(first, k -> new LinkedHashMap<Integer, String>());
Pair<Integer, String> second = pair.getSecond();
comments.put(second.getFirst(), second.getSecond());
}
assertEquals(expected.toString(), actual.toString());
}
use of com.querydsl.core.Tuple in project querydsl by querydsl.
the class ConstantHidingExpressionTest method constants_hidden.
@Test
public void constants_hidden() {
FactoryExpression<Tuple> tuple = Projections.tuple(Expressions.stringPath("str"), Expressions.TRUE, Expressions.FALSE.as("false"), Expressions.constant(1));
FactoryExpression<Tuple> wrapped = new ConstantHidingExpression<Tuple>(tuple);
assertEquals(1, wrapped.getArgs().size());
Tuple t = wrapped.newInstance("s");
assertEquals("s", t.get(Expressions.stringPath("str")));
assertEquals(Boolean.TRUE, t.get(Expressions.TRUE));
assertEquals(Boolean.FALSE, t.get(Expressions.FALSE.as("false")));
assertEquals(Integer.valueOf(1), t.get(Expressions.constant(1)));
}
use of com.querydsl.core.Tuple in project querydsl by querydsl.
the class NumberConversionsTest method name.
@Test
public void name() {
EnumPath<Color> color = Expressions.enumPath(Color.class, "path");
QTuple qTuple = Projections.tuple(color);
NumberConversions<Tuple> conversions = new NumberConversions<Tuple>(qTuple);
assertEquals(Color.BLUE, conversions.newInstance("BLUE").get(color));
}
Aggregations