blob: b75b8ae59a75e26ef44c8a73746ff53c1c0fb517 [file] [log] [blame]
Umesh Krishnaswamy345ee992012-12-13 20:29:48 -08001/**
2* Copyright 2011, Big Switch Networks, Inc.
3* Originally created by David Erickson, Stanford University
4*
5* Licensed under the Apache License, Version 2.0 (the "License"); you may
6* not use this file except in compliance with the License. You may obtain
7* a copy of the License at
8*
9* http://www.apache.org/licenses/LICENSE-2.0
10*
11* Unless required by applicable law or agreed to in writing, software
12* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14* License for the specific language governing permissions and limitations
15* under the License.
16**/
17
18package net.floodlightcontroller.storage;
19
20/** Representation of a database query. For SQL queries this maps to
21 * a prepared statement, so it will be more efficient than if you use the
22 * methods in IStorageSource that bypass the IQuery. For many NoSQL
23 * storage sources there won't be any performance improvement from keeping
24 * around the query.
25 *
26 * The query interface also supports parameterized queries (i.e. which maps
27 * to using ? values in a SQL query). The values of the parameters are set
28 * using the setParameter method. In the storage source API the parameters
29 * are named rather than positional. The format of the parameterized values
30 * in the query predicates is the parameter name bracketed with question marks
31 * (e.g. ?MinimumSalary? ).
32 *
33 * @author rob
34 *
35 */
36public interface IQuery {
37 String getTableName();
38 void setParameter(String name, Object value);
39}