querydsl/querydsl-sql/src/main/java/com/mysema/query/sql/AbstractSQLSubQuery.java
Timo Westkämper 212b3eceb4 cleaned code
2010-06-21 16:07:45 +00:00

95 lines
2.4 KiB
Java

/*
* Copyright (c) 2010 Mysema Ltd.
* All rights reserved.
*
*/
package com.mysema.query.sql;
import com.mysema.query.DefaultQueryMetadata;
import com.mysema.query.QueryMetadata;
import com.mysema.query.support.DetachableQuery;
import com.mysema.query.support.QueryMixin;
import com.mysema.query.types.Path;
import com.mysema.query.types.SubQuery;
import com.mysema.query.types.expr.EBoolean;
import com.mysema.query.types.path.PEntity;
/**
* Abstract superclass for SubQuery implementations
*
* @author tiwe
*
*/
public class AbstractSQLSubQuery<Q extends AbstractSQLSubQuery<Q>> extends DetachableQuery<Q> {
public AbstractSQLSubQuery() {
this(new DefaultQueryMetadata());
}
@SuppressWarnings("unchecked")
public AbstractSQLSubQuery(QueryMetadata metadata) {
super(new QueryMixin<Q>(metadata));
this.queryMixin.setSelf((Q)this);
}
public Q from(PEntity<?>... args){
return queryMixin.from(args);
}
public Q fullJoin(PEntity<?> target) {
return queryMixin.fullJoin(target);
}
public Q fullJoin(SubQuery<?> target, Path<?> alias) {
return queryMixin.fullJoin(target, alias);
}
public Q innerJoin(PEntity<?> target) {
return queryMixin.innerJoin(target);
}
public Q innerJoin(SubQuery<?> target, Path<?> alias) {
return queryMixin.innerJoin(target, alias);
}
public Q join(PEntity<?> target) {
return queryMixin.join(target);
}
public Q join(SubQuery<?> target, Path<?> alias) {
return queryMixin.join(target, alias);
}
public Q leftJoin(PEntity<?> target) {
return queryMixin.leftJoin(target);
}
public Q leftJoin(SubQuery<?> target, Path<?> alias) {
return queryMixin.leftJoin(target, alias);
}
public Q rightJoin(PEntity<?> target) {
return queryMixin.leftJoin(target);
}
public Q rightJoin(SubQuery<?> target, Path<?> alias) {
return queryMixin.leftJoin(target, alias);
}
public Q on(EBoolean... conditions){
return queryMixin.on(conditions);
}
@Override
public String toString(){
if (!queryMixin.getMetadata().getJoins().isEmpty()){
SQLSerializer serializer = new SQLSerializer(SQLTemplates.DEFAULT);
serializer.serialize(queryMixin.getMetadata(), false);
return serializer.toString().trim();
}else{
return super.toString();
}
}
}