/* * Geotoolkit.org - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2005-2012, Open Source Geospatial Foundation (OSGeo) * (C) 2007-2012, Geomatys * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. */ package org.geotoolkit.coverage.sql; import org.geotoolkit.internal.sql.table.Column; import org.geotoolkit.internal.sql.table.Database; import org.geotoolkit.internal.sql.table.Parameter; import org.geotoolkit.internal.sql.table.Query; import org.geotoolkit.internal.sql.table.QueryType; import static org.geotoolkit.internal.sql.table.QueryType.*; /** * The query to execute for a {@link SeriesTable}. * * @author Martin Desruisseaux (IRD, Geomatys) * @version 3.10 * * @since 3.10 (derived from Seagis) * @module */ final class SeriesQuery extends Query { /** * Column to appear after the {@code "SELECT"} clause. */ final Column identifier, layer, pathname, extension, format, comments; /** * Parameter to appear after the {@code "FROM"} clause. */ final Parameter byIdentifier, byLayer; /** * Creates a new query for the specified database. * * @param database The database for which this query is created. */ public SeriesQuery(final Database database) { super(database, "Series"); final QueryType[] sle = {SELECT, LIST, EXISTS}; final QueryType[] sli = {SELECT, LIST, INSERT}; identifier = addMandatoryColumn("identifier", sle); layer = addMandatoryColumn("layer", INSERT); pathname = addMandatoryColumn("pathname", sli); extension = addMandatoryColumn("extension", sli); format = addMandatoryColumn("format", sli); comments = addOptionalColumn ("comments", null, SELECT, LIST); byIdentifier = addParameter(identifier, SELECT, EXISTS, DELETE); byLayer = addParameter(layer, LIST, DELETE_ALL); } }