/*
This file belongs to the Servoy development and deployment environment, Copyright (C) 1997-2012 Servoy BV
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU Affero General Public License as published by the Free
Software Foundation; either version 3 of the License, or (at your option) any
later version.
This program 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 Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along
with this program; if not, see http://www.gnu.org/licenses or write to the Free
Software Foundation,Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
*/
package com.servoy.j2db.querybuilder;
import com.servoy.j2db.persistence.RepositoryException;
/**
* Where clause for a query, conditions can be added by name.
*
* @author rgansevles
*
* @since 6.1
*/
public interface IQueryBuilderWhereCondition extends IQueryBuilderLogicalCondition
{
/**
* Add a named condition to the AND or OR condition list.
* <pre>
* query.where().add("mycond", query.getColumn("flag").eq(new Integer(1))).add(query.getColumn("value").isNull());
* </pre>
*/
IQueryBuilderWhereCondition add(String name, IQueryBuilderCondition condition) throws RepositoryException;
/**
* Get the names for the conditions in the query where-clause.
*/
String[] conditionnames();
/**
* Remove a named condition from the AND or OR condition list.
* <pre>
* query.where().remove("mycond");
* </pre>
*/
IQueryBuilderWhereCondition remove(String name);
/**
* Clear the conditions in the query where-clause.
*/
IQueryBuilderWhereCondition clear();
/**
* Get a named condition in the query where-clause.
*/
IQueryBuilderCondition getCondition(String name);
}