/* * DBeaver - Universal Database Manager * Copyright (C) 2010-2017 Serge Rider (serge@jkiss.org) * * 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.jkiss.dbeaver.model.impl.sql; import net.sf.jsqlparser.JSQLParserException; import net.sf.jsqlparser.expression.Expression; import net.sf.jsqlparser.expression.Function; import net.sf.jsqlparser.expression.operators.relational.ExpressionList; import net.sf.jsqlparser.parser.CCJSqlParserUtil; import net.sf.jsqlparser.schema.Column; import net.sf.jsqlparser.statement.Statement; import net.sf.jsqlparser.statement.select.PlainSelect; import net.sf.jsqlparser.statement.select.Select; import net.sf.jsqlparser.statement.select.SelectExpressionItem; import net.sf.jsqlparser.statement.select.SelectItem; import org.jkiss.dbeaver.DBException; import org.jkiss.dbeaver.model.sql.SQLDataSource; import org.jkiss.dbeaver.model.sql.SQLQuery; import org.jkiss.dbeaver.model.sql.SQLQueryTransformer; import java.util.ArrayList; import java.util.Collections; import java.util.List; /** * SQLQueryTransformerCount. * Transforms SQL query into SELECT COUNT(*) query */ public class SQLQueryTransformerCount implements SQLQueryTransformer { @Override public SQLQuery transformQuery(SQLDataSource dataSource, SQLQuery query) throws DBException { try { Statement statement = CCJSqlParserUtil.parse(query.getText()); if (statement instanceof Select && ((Select) statement).getSelectBody() instanceof PlainSelect) { PlainSelect select = (PlainSelect) ((Select) statement).getSelectBody(); List<SelectItem> selectItems = new ArrayList<>(); Function countFunc = new Function(); countFunc.setName("count"); countFunc.setParameters(new ExpressionList(Collections.<Expression>singletonList(new Column("*")))); SelectItem countItem = new SelectExpressionItem(countFunc); selectItems.add(countItem); select.setSelectItems(selectItems); return new SQLQuery(dataSource, select.toString(), query, false); } else { throw new DBException("Query [" + query.getText() + "] can't be modified"); } } catch (JSQLParserException e) { throw new DBException("Can't transform query to SELECT count(*)", e); } } }