本文整理汇总了Java中com.mysema.query.types.Expression类的典型用法代码示例。如果您正苦于以下问题:Java Expression类的具体用法?Java Expression怎么用?Java Expression使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
Expression类属于com.mysema.query.types包,在下文中一共展示了Expression类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: buildOrderPropertyPathFrom
import com.mysema.query.types.Expression; //导入依赖的package包/类
private Expression<?> buildOrderPropertyPathFrom(JoinerQuery<?, ?> joinerQuery, Sort.Order order) {
PathBuilder<?> builder = new PathBuilder<Object>(joinerQuery.getFrom().getType(), joinerQuery.getFrom().toString());
PropertyPath path = PropertyPath.from(order.getProperty(), builder.getType());
Expression<?> sortPropertyExpression = builder;
while (path != null) {
if (!path.hasNext() && order.isIgnoreCase()) {
// if order is ignore-case we have to treat the last path segment as a String.
sortPropertyExpression = Expressions.stringPath((Path<?>) sortPropertyExpression, path.getSegment()).lower();
} else {
sortPropertyExpression = Expressions.path(path.getType(), (Path<?>) sortPropertyExpression, path.getSegment());
}
path = path.next();
}
return sortPropertyExpression;
}
示例2: evaluate
import com.mysema.query.types.Expression; //导入依赖的package包/类
public void evaluate(String expression, QueryDslContext context, ParserConfig config) {
List<Node> nodeList = Evaluator.parse(expression, config);
for (Node node : nodeList) {
if (node instanceof LogicalNode) {
Predicate filter = node.accept(visitor, context);
if (node instanceof OrNode) {
context.addOr(filter);
} else {
context.addAnd(filter);
}
} else if (node instanceof FilterNode) {
Predicate filterNode = node.accept(visitor, context);
context.addAnd(filterNode);
} else if (node instanceof OrderNode) {
LinkedList order = (LinkedList<OrderSpecifier>) node.accept(visitor, context);
context.setOrderSpecifiers(order);
} else if (node instanceof LimitNode) {
QueryModifiers modifiers = (QueryModifiers) (Object) node.accept(visitor, context);
context.setQueryModifiers(modifiers);
} else if (node instanceof ProjectionNode) {
Expression projection = (QBean) node.accept(visitor, context);
context.setProjection(projection);
}
}
}
示例3: downloadMain
import com.mysema.query.types.Expression; //导入依赖的package包/类
private long downloadMain(QueryConfigurer commonClause, QueryConfigurer orderByClause, Consumer consumer,
Limiter limiter, Expression<?>... expressions) throws LimiterException, IOException {
ResultSetExtractor<Long> extractor = new ExtractorResultSetExtractor(consumer, limiter);
limiter.start();
try {
SQLQuery query = queryDslJdbcOperations.newSqlQuery();
query = commonClause.configure(query);
query = orderByClause.configure(query);
return queryDslJdbcOperations.queryForObject(query, extractor, expressions);
} catch (IllegalStateException ex) {
throw (IOException) ex.getCause();
} finally {
limiter.stop();
}
}
示例4: downloadXls
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Transactional
@Override
public void downloadXls(HttpServletResponse response, String filename, LocalDateTime timestamp,
final List<String> header, final QueryConfigurer commonClause, final QueryConfigurer orderByClause,
final Expression<?>... expressions) throws IOException {
downloadOperation.download(response, excelType, null, filename, timestamp, new DownloadAction() {
@Override
public long doDownload(OutputStream stream) throws IOException {
try (Workbook workbook = ExcelFactory.createBlankXls(); ExcelWriter writer = new ExcelWriter(workbook)) {
Consumer consumer = createExcelConsumer(writer, header);
long count = queryDslSupport.download(commonClause, orderByClause, consumer, expressions);
workbook.write(stream);
return count;
}
}
});
}
示例5: downloadXlsx
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Transactional
@Override
public void downloadXlsx(HttpServletResponse response, String filename, LocalDateTime timestamp,
final List<String> header, final QueryConfigurer commonClause, final QueryConfigurer orderByClause,
final Expression<?>... expressions) throws IOException {
downloadOperation.download(response, excelType, null, filename, timestamp, new DownloadAction() {
@Override
public long doDownload(OutputStream stream) throws IOException {
try (Workbook workbook = ExcelFactory.createBlankXlsx(); ExcelWriter writer = new ExcelWriter(workbook)) {
Consumer consumer = createExcelConsumer(writer, header);
long count = queryDslSupport.download(commonClause, orderByClause, consumer, expressions);
workbook.write(stream);
return count;
}
}
});
}
示例6: QAuthor
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Test
public void sec020201_定数値をカラムとして照会する() {
Expression<Integer> const1 = Expressions.constant(1);
Expression<String> const2 = Expressions.constant("string");
QAuthor a = new QAuthor("a");
SQLQuery query = queryDslJdbcOperations.newSqlQuery();
query.from(a);
List<Tuple> list = queryDslJdbcOperations.query(query, new QTuple(a.id,
const1, const2));
for (Tuple tuple : list) {
Long valId = tuple.get(a.id);
Integer valConst1 = tuple.get(const1);
String valConst2 = tuple.get(const2);
out.println(format("{0}: const1={1}, const2={2}", valId, valConst1,
valConst2));
}
}
示例7: testNamedSetExpression
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Test
public void testNamedSetExpression() {
Expression<Set<String>> expr = DatabaseUtils.namedExpression("test");
QTuple q = new QTuple(expr);
Tuple t = q.newInstance(Collections.singleton("Hello, world!"));
assertNotNull(t);
Set<String> result = t.get(expr);
assertNotNull(result);
Iterator<String> itr = result.iterator();
assertTrue(itr.hasNext());
assertEquals("Hello, world!", itr.next());
assertFalse(itr.hasNext());
}
示例8: QTodo
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Test
public void sec020501_CASE式を指定する_単純CASE式() {
/* 抽出条件を組み立てる。 */
QTodo a = new QTodo("a");
SQLQuery query = queryDslJdbcOperations.newSqlQuery();
query.from(a);
/* CASE式を組立てる。 */
Expression<String> doneDesc = a.doneFlg.when(0).then("未実施").when(1)
.then("実施済").otherwise("不定");
/* 取出すカラムとデータの取出し方を指定してクエリを発行する。 */
List<Tuple> list = queryDslJdbcOperations.query(query, new QTuple(a.id,
a.doneFlg, doneDesc));
/* クエリの結果を表示する。 */
for (Tuple tuple : list) {
Long valId = tuple.get(a.id);
Integer valDoneFlg = tuple.get(a.doneFlg);
String valDoneDesc = tuple.get(doneDesc);
out.println(format("{0}: doneFlg={1}, doneDesc(CASE)={2}", valId,
valDoneFlg, valDoneDesc));
}
}
示例9: testDetectedWrongOrder
import com.mysema.query.types.Expression; //导入依赖的package包/类
@SuppressWarnings("unchecked")
@Test(expected=IllegalArgumentException.class)
public void testDetectedWrongOrder() {
Expression<Integer> idExpr = mock(Expression.class);
Expression<String> valueExpr = mock(Expression.class);
List<Tuple> tuples = new ArrayList<Tuple>();
Random r = new Random(0);
for(int i = 0; i < 10; i++) {
Tuple a = mock(Tuple.class);
when(a.get(idExpr)).thenReturn(r.nextInt());
when(a.get(valueExpr)).thenReturn("" + i + "a");
Tuple b = mock(Tuple.class);
when(b.get(idExpr)).thenReturn(i);
when(b.get(valueExpr)).thenReturn("" + i + "b");
tuples.add(a);
tuples.add(b);
}
ListIterator<Tuple> itr = tuples.listIterator();
DatabaseUtils.consumeList(itr, 42, idExpr, t -> t.get(valueExpr));
}
示例10: afterPropertiesSet
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Override
public void afterPropertiesSet() {
QSqlClause c = new QSqlClause("c");
QSqlStatement s = new QSqlStatement("s");
QSqlLoad l = new QSqlLoad("l");
StringExpression databaseName = cases() //
.when(m.sqlType.eq(SqlType.CLAUSE.code())) //
.then(new SQLSubQuery().from(c).where(c.id.eq(m.id)).unique(c.databaseName)) //
.when(m.sqlType.eq(SqlType.STATEMENT.code())) //
.then(new SQLSubQuery().from(s).where(s.id.eq(m.id)).unique(s.databaseName)) //
.when(m.sqlType.eq(SqlType.LOAD.code())) //
.then(new SQLSubQuery().from(l).where(l.id.eq(m.id)).unique(l.databaseName)) //
.otherwise(StringUtils.EMPTY).as(getColumnMetadata(c.databaseName).getName());
List<Expression<?>> list = new ArrayList<>(m.all().length + 1);
for (Path<?> e : m.all()) {
list.add(e);
}
list.add(databaseName);
expressions = list.toArray(new Expression<?>[list.size()]);
}
示例11: downloadMain
import com.mysema.query.types.Expression; //导入依赖的package包/类
private long downloadMain(QueryConfigurer commonClause, QueryConfigurer orderByClause, Consumer consumer,
Limiter limiter, Expression<?>... expressions) throws LimiterException, IOException {
limiter.start();
try {
SQLQuery query = commonClause.configure(queryFactory.query());
query = orderByClause.configure(query);
ResultSetExtractor<Long> extractor = new ExtractorResultSetExtractor(consumer, limiter);
return getResults("download", query, extractor, expressions);
} catch (IllegalStateException ex) {
throw (IOException) ex.getCause();
} finally {
limiter.stop();
}
}
示例12: join
import com.mysema.query.types.Expression; //导入依赖的package包/类
/**
* Performs an inner join on provided streams.
*
* Consider using {@link #join(Collection, Collection, Expression, Expression...)} for streams
* obtained from a {@link Collection}.
*
* @param left left stream.
* @param right right stream.
* @param firstExpr first join condition.
* @param otherExprs additional join conditions.
* @return the join result.
*/
@SafeVarargs
public static <T extends Comparable<? super T>> Stream<Tuple> join(Stream<Tuple> left, Stream<Tuple> right, Expression<? extends T> firstExpr, Expression<? extends T>... otherExprs) {
return StreamUtils
.mergeJoin(
left,
right,
comparing(firstExpr, otherExprs)::compare,
Collectors.toList(),
Collectors.toList(),
(leftResult, rightResult) ->
// generate a JoinedTuple for every combination of leftResult and rightResult.
leftResult.stream()
.<Tuple>flatMap(leftItem ->
rightResult.stream()
.<Tuple>map(rightItem -> (Tuple)new JoinedTuple(leftItem, rightItem))))
.flatMap(Function.identity()); // convert Stream<Stream<Tuple>> into Stream<Tuple>.
}
示例13: createSuperTuple
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Before
@SuppressWarnings("unchecked")
public void createSuperTuple() {
id = (Expression<Integer>)mock(Expression.class);
stringValue = (Expression<String>)mock(Expression.class);
doubleValue = (Expression<Double>)mock(Expression.class);
Tuple parentTuple = mock(Tuple.class);
when(parentTuple.size()).thenReturn(2);
when(parentTuple.toArray()).thenReturn(new Object[]{0, "Hello, world!"});
when(parentTuple.get(id)).thenReturn(0);
when(parentTuple.get(stringValue)).thenReturn("Hello, world!");
when(parentTuple.get(0, Integer.class)).thenReturn(0);
when(parentTuple.get(1, String.class)).thenReturn("Hello, world!");
Tuple tuple = mock(Tuple.class);
when(tuple.size()).thenReturn(2);
when(tuple.toArray()).thenReturn(new Object[]{0, 42.0});
when(tuple.get(id)).thenReturn(0);
when(tuple.get(doubleValue)).thenReturn(42.0);
when(tuple.get(0, Integer.class)).thenReturn(0);
when(tuple.get(1, Double.class)).thenReturn(42.0);
superTuple = new JoinedTuple(parentTuple, tuple);
}
示例14: downloadXlsx
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Transactional
@Override
public void downloadXlsx(HttpServletResponse response, String filename, LocalDateTime timestamp,
final List<String> header, final QueryConfigurer commonClause, final QueryConfigurer orderByClause,
final Expression<?>... expressions) {
downloadOperation.download(response, excelType, null, filename, timestamp, new DownloadAction() {
@Override
public long doDownload(OutputStream stream) throws IOException {
try (Workbook workbook = ExcelFactory.createBlankXlsx(); ExcelWriter writer = new ExcelWriter(workbook)) {
Consumer consumer = createExcelConsumer(writer, header);
long count = queryDslSupport.download(commonClause, orderByClause, consumer, expressions);
workbook.write(stream);
return count;
}
}
});
}
示例15: tupleToMap
import com.mysema.query.types.Expression; //导入依赖的package包/类
@Test
public void tupleToMap() {
Expression<String> string = constant("string");
Expression<String> stringWithName = as(string, "aaa");
List<Tuple> list = queryFactory.query().list(string, stringWithName);
PagedList<Tuple> pagedList = new PagedList<>();
pagedList.setPageSet(new PageSet());
pagedList.setList(list);
PagedList<Map<String, ?>> plist = QueryDslUtil.tupleToMap(pagedList, string, stringWithName);
assertEquals(pagedList.getPageSet(), plist.getPageSet());
assertEquals(1, plist.getList().size());
assertEquals(1, plist.getList().get(0).entrySet().size());
assertEquals("string", plist.getList().get(0).get("aaa"));
}