/*
* Copyright 2014 Dayatang Open Source..
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.dayatang.querychannel.query;
import org.dayatang.domain.BaseQuery;
import org.dayatang.domain.Entity;
import org.dayatang.domain.EntityRepository;
import org.dayatang.domain.SqlQuery;
import org.dayatang.querychannel.ChannelQuery;
import org.dayatang.utils.Assert;
import org.dayatang.utils.Page;
import java.util.List;
/**
* 通道查询的SQL实现
* @author yyang
*/
public class ChannelSqlQuery extends ChannelQuery<ChannelSqlQuery> {
private final SqlQuery query;
public ChannelSqlQuery(EntityRepository repository, String sql) {
super(repository);
Assert.notBlank(sql, "SQL must be set!");
query = new SqlQuery(repository, sql);
setQuery(query);
}
/**
* 设置查询的结果实体类型。注意setResultEntityClass()和addScalar()是互斥的,
* 分别适用于查询结果是实体和标量两种情形
* @param resultEntityClass 要设置的查询结果类型
* @return 该对象本身
*/
public ChannelSqlQuery setResultEntityClass(Class<? extends Entity> resultEntityClass) {
query.setResultEntityClass(resultEntityClass);
return this;
}
@Override
public <T> List<T> list() {
return query.list();
}
@Override
public <T> Page<T> pagedList() {
return new Page<T>(query.getFirstResult(), queryResultCount(),
query.getMaxResults(), (List<T>) query.list());
}
@Override
public <T> T singleResult() {
return (T) query.singleResult();
}
@Override
protected String getQueryString() {
return query.getSql();
}
@Override
protected BaseQuery createBaseQuery(String queryString) {
return repository.createSqlQuery(queryString);
}
}