//
//  $Id: QKQuery.h 3421 2011-09-10 22:58:45Z stuart02 $
//
//  QKQuery.h
//  QueryKit
//
//  Created by Stuart Connolly (stuconnolly.com) on September 4, 2011
//  Copyright (c) 2011 Stuart Connolly. All rights reserved.
//
//  Permission is hereby granted, free of charge, to any person
//  obtaining a copy of this software and associated documentation
//  files (the "Software"), to deal in the Software without
//  restriction, including without limitation the rights to use,
//  copy, modify, merge, publish, distribute, sublicense, and/or sell
//  copies of the Software, and to permit persons to whom the
//  Software is furnished to do so, subject to the following
//  conditions:
//
//  The above copyright notice and this permission notice shall be
//  included in all copies or substantial portions of the Software.
//
//  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
//  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
//  OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
//  NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
//  HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
//  WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
//  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
//  OTHER DEALINGS IN THE SOFTWARE.

#import "QKQueryTypes.h"
#import "QKQueryDatabases.h"
#import "QKQueryOperators.h"

@class QKQueryOrderBy;
@class QKQueryParameter;
@class QKQueryUpdateParameter;

/**
 * @class QKQuery QKQuery.h
 *
 * @author Stuart Connolly http://stuconnolly.com/
 *
 * Main QueryKit query class.
 */
@interface QKQuery : NSObject 
{
	NSString *_database;
	NSString *_table;
	NSString *_identifierQuote;
	
	NSMutableString *_query;
	
	NSMutableArray *_parameters;
	NSMutableArray *_fields;
	NSMutableArray *_updateParameters;
	NSMutableArray *_groupByFields;
	NSMutableArray *_orderByFields;
	
	QKQueryType _queryType;
	QKQueryDatabase _queryDatabase;
	
	BOOL _useQuotedIdentifiers;
}

/**
 * @property database The database the query is to be run against (optional).
 */
@property(readwrite, retain) NSString *database;

/**
 * @property table The table the query is to be run against.
 */
@property(readwrite, retain) NSString *table; 

/**
 * @property parameters The parameters (constraints) of the query.
 */
@property(readwrite, retain) NSMutableArray *parameters;

/**
 * @property fields The fields of the query.
 */
@property(readwrite, retain) NSMutableArray *fields;

/**
 * @property updateFields The fields of an UPDATE query.
 */
@property(readwrite, retain) NSMutableArray *updateParameters;

/**
 * @property queryType The type of query to be built.
 */
@property(readwrite, assign) QKQueryType queryType;

/**
 * @property queryDatabase The underlying database system this query will be run against.
 */
@property(readwrite, assign) QKQueryDatabase queryDatabase;

/**
 * @property useQuotedIdentifiers Indicates whether or not the query's fields should be quoted.
 */
@property(readwrite, assign) BOOL useQuotedIdentifiers;

/**
 * @property groupByFields The group by fields of the query.
 */
@property(readonly) NSMutableArray *groupByFields;

/**
 * @property orderByFields The order by fields of the query.
 */
@property(readonly) NSMutableArray *orderByFields;

/**
 * @property identifierQuote The character to use when quoting identifiers.
 */
@property(readonly) NSString *identifierQuote;

+ (QKQuery *)queryTable:(NSString *)table;
+ (QKQuery *)queryTable:(NSString *)table database:(NSString *)database;

+ (QKQuery *)selectQueryFromTable:(NSString *)table;
+ (QKQuery *)selectQueryFromTable:(NSString *)table database:(NSString *)database;

- (id)initWithTable:(NSString *)table;
- (id)initWithTable:(NSString *)table database:(NSString *)database;

- (NSString *)query;
- (void)clear;

- (void)addField:(NSString *)field;
- (void)addFields:(NSArray *)fields;

- (void)addParameter:(QKQueryParameter *)parameter;
- (void)addParameter:(NSString *)field operator:(QKQueryOperator)operator value:(id)value;

- (void)addFieldToUpdate:(QKQueryUpdateParameter *)parameter;
- (void)addFieldToUpdate:(NSString *)field toValue:(id)value;

- (void)groupByField:(NSString *)field;
- (void)groupByFields:(NSArray *)fields;

- (void)orderBy:(QKQueryOrderBy *)orderBy;
- (void)orderByField:(NSString *)field descending:(BOOL)descending;

@end