All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jooq.impl.QueriesImpl Maven / Gradle / Ivy

The newest version!
/*
 * 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
 *
 *  https://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.
 *
 * Other licenses:
 * -----------------------------------------------------------------------------
 * Commercial licenses for this work are available. These replace the above
 * Apache-2.0 license and offer limited warranties, support, maintenance, and
 * commercial database integrations.
 *
 * For more information, please visit: https://www.jooq.org/legal/licensing
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 */
package org.jooq.impl;

import static org.jooq.impl.Tools.EMPTY_QUERY;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.function.Predicate;
import java.util.regex.Pattern;
import java.util.stream.Stream;

import org.jooq.Batch;
import org.jooq.Block;
import org.jooq.Configuration;
import org.jooq.Context;
import org.jooq.DSLContext;
import org.jooq.Function1;
import org.jooq.Queries;
import org.jooq.Query;
import org.jooq.QueryPart;
// ...
import org.jooq.ResultQuery;
import org.jooq.Results;
// ...
import org.jooq.impl.DefaultParseContext.IgnoreQuery;
import org.jooq.impl.QOM.UnmodifiableList;
import org.jooq.impl.ResultsImpl.ResultOrRowsImpl;

/**
 * @author Lukas Eder
 */
final class QueriesImpl extends AbstractAttachableQueryPart implements Queries {

    private final QueryPartList queries;

    QueriesImpl(Configuration configuration, Collection queries) {
        super(configuration);

        this.queries = new QueryPartList<>(queries);
    }

    // ------------------------------------------------------------------------
    // Access API
    // ------------------------------------------------------------------------

    @Override
    public final Queries concat(Queries other) {
        Query[] array = other.queries();
        List list = new ArrayList<>(queries.size() + array.length);
        list.addAll(queries);
        list.addAll(Arrays.asList(array));
        return new QueriesImpl(configuration(), list);
    }

    @Override
    public final Query[] queries() {
        return queries.toArray(EMPTY_QUERY);
    }

    @Override
    public final Block block() {
        return configurationOrDefault().dsl().begin(queries);
    }

    @Override
    public final Batch batch() {
        return configurationOrDefault().dsl().batch(queries);
    }

    @Override
    public final Iterator iterator() {
        return queries.iterator();
    }

    @Override
    public final Stream stream() {
        return queryStream();
    }

    @Override
    public final Stream queryStream() {
        return queries.stream();
    }

    // ------------------------------------------------------------------------
    // Execution API
    // ------------------------------------------------------------------------

    @Override
    public final Results fetchMany() {
        Configuration c = configurationOrThrow();
        ResultsImpl results = new ResultsImpl(c);
        DSLContext ctx = c.dsl();

        for (Query query : this)
            if (query instanceof ResultQuery q)
                results.resultsOrRows.addAll(ctx.fetchMany(q).resultsOrRows());
            else
                results.resultsOrRows.add(new ResultOrRowsImpl(ctx.execute(query)));

        return results;
    }

    @Override
    public final int[] executeBatch() {
        return configurationOrThrow().dsl().batch(this).execute();
    }

    // ------------------------------------------------------------------------
    // QueryPart API
    // ------------------------------------------------------------------------

    private static final Pattern P_IGNORE_FORMATTED   = Pattern.compile("^(?sm:\\n? *(.*?) *\\n?)$");
    private static final Pattern P_IGNORE_UNFORMATTED = Pattern.compile("^(?sm: *(.*?) *)$");

    @Override
    public final void accept(Context ctx) {
        boolean first = true;
        boolean separatorRequired = false;

        for (Query query : this) {
            boolean i = query instanceof IgnoreQuery;

            if (first)
                first = false;
            else if (separatorRequired)
                ctx.formatSeparator();

            if (i)
                if (ctx.format())
                    query = new IgnoreQuery(P_IGNORE_FORMATTED.matcher(((IgnoreQuery) query).sql).replaceFirst("$1"));
                else
                    query = new IgnoreQuery(P_IGNORE_UNFORMATTED.matcher(((IgnoreQuery) query).sql).replaceFirst("$1"));

            ctx.visit(query);

            if (!i)
                ctx.sql(';');

            separatorRequired = !i || !((IgnoreQuery) query).sql.endsWith("\n");
        }
    }

    // -------------------------------------------------------------------------
    // XXX: Query Object Model
    // -------------------------------------------------------------------------

    @Override
    public final UnmodifiableList $queries() {
        return QOM.unmodifiable(queries);
    }















    // ------------------------------------------------------------------------
    // Object API
    // ------------------------------------------------------------------------

    @Override
    public int hashCode() {
        return queries.hashCode();
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;

        if (!(obj instanceof QueriesImpl))
            return false;

        return queries.equals(((QueriesImpl) obj).queries);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy