2004-04-17 11:30:47 +00:00
|
|
|
/* -*-objc-*-
|
2002-11-15 22:57:05 +00:00
|
|
|
EOSQLExpression.h
|
|
|
|
|
2005-08-17 08:07:57 +00:00
|
|
|
Copyright (C) 2000,2002,2003,2004,2005 Free Software Foundation, Inc.
|
2002-11-15 22:57:05 +00:00
|
|
|
|
2006-09-14 16:06:21 +00:00
|
|
|
Author: Mirko Viviani <mirko.viviani@gmail.com>
|
2002-11-15 22:57:05 +00:00
|
|
|
Date: February 2000
|
|
|
|
|
|
|
|
This file is part of the GNUstep Database Library.
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Library General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
2007-07-12 06:39:22 +00:00
|
|
|
version 3 of the License, or (at your option) any later version.
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
|
|
License along with this library; see the file COPYING.LIB.
|
|
|
|
If not, write to the Free Software Foundation,
|
2005-08-17 08:07:57 +00:00
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2002-11-15 22:57:05 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __EOSQLExpression_h__
|
|
|
|
#define __EOSQLExpression_h__
|
|
|
|
|
2004-03-19 16:41:21 +00:00
|
|
|
#ifdef GNUSTEP
|
2003-03-31 00:24:15 +00:00
|
|
|
#include <Foundation/NSObject.h>
|
|
|
|
#include <Foundation/NSString.h>
|
|
|
|
#include <Foundation/NSValue.h>
|
|
|
|
#else
|
|
|
|
#include <Foundation/Foundation.h>
|
|
|
|
#endif
|
2002-11-15 22:57:05 +00:00
|
|
|
|
2003-03-31 00:24:15 +00:00
|
|
|
#include <EOAccess/EOJoin.h>
|
|
|
|
#include <EOAccess/EORelationship.h>
|
|
|
|
#include <EOAccess/EODefines.h>
|
2002-11-15 22:57:05 +00:00
|
|
|
|
2002-12-30 22:10:43 +00:00
|
|
|
|
|
|
|
@class NSArray;
|
|
|
|
@class NSMutableArray;
|
|
|
|
@class NSDictionary;
|
|
|
|
@class NSMutableDictionary;
|
|
|
|
|
2002-11-15 22:57:05 +00:00
|
|
|
@class EOAttribute;
|
|
|
|
@class EOEntity;
|
|
|
|
@class EOQualifier;
|
2002-12-30 22:10:43 +00:00
|
|
|
@class EOKeyValueQualifier;
|
|
|
|
@class EOKeyComparisonQualifier;
|
|
|
|
@class EOSortOrdering;
|
|
|
|
@class EOFetchSpecification;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
|
2003-03-31 00:24:15 +00:00
|
|
|
GDL2ACCESS_EXPORT NSString *EOBindVariableNameKey;
|
|
|
|
GDL2ACCESS_EXPORT NSString *EOBindVariableAttributeKey;
|
|
|
|
GDL2ACCESS_EXPORT NSString *EOBindVariableValueKey;
|
|
|
|
GDL2ACCESS_EXPORT NSString *EOBindVariablePlaceHolderKey;
|
|
|
|
GDL2ACCESS_EXPORT NSString *EOBindVariableColumnKey;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
@interface EOSQLExpression : NSObject
|
|
|
|
{
|
|
|
|
NSMutableDictionary *_aliasesByRelationshipPath;
|
|
|
|
EOEntity *_entity;
|
|
|
|
NSMutableString *_listString;
|
|
|
|
NSMutableString *_valueListString;
|
|
|
|
NSString *_whereClauseString;
|
|
|
|
NSMutableString *_joinClauseString;
|
|
|
|
NSMutableString *_orderByString;
|
|
|
|
NSMutableArray *_bindings;
|
|
|
|
NSMutableArray *_contextStack;
|
|
|
|
NSString *_statement;
|
2003-11-28 22:50:52 +00:00
|
|
|
struct {
|
|
|
|
unsigned int useAliases:1;
|
|
|
|
unsigned int hasOuterJoin:1;
|
|
|
|
unsigned int _reserved:30;
|
|
|
|
} _flags;
|
2002-11-15 22:57:05 +00:00
|
|
|
@private
|
|
|
|
int _alias;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ (EOSQLExpression *)expressionForString: (NSString *)string;
|
|
|
|
|
|
|
|
+ (EOSQLExpression *)insertStatementForRow: (NSDictionary *)row
|
|
|
|
entity: (EOEntity *)entity;
|
|
|
|
|
|
|
|
+ (EOSQLExpression *)updateStatementForRow: (NSDictionary *)row
|
|
|
|
qualifier: (EOQualifier *)qualifier
|
|
|
|
entity: (EOEntity *)entity;
|
|
|
|
|
2004-04-17 11:30:47 +00:00
|
|
|
/* The endity parameter is typed to 'id' for signature compatibility
|
|
|
|
with EOF. Note that only EOEntity * objects should be passed. */
|
2002-11-15 22:57:05 +00:00
|
|
|
+ (EOSQLExpression *)deleteStatementWithQualifier: (EOQualifier *)qualifier
|
* EOAccess/EOSQLExpression.h (deleteStatementWithQualifier:entity:)
* EOAccess/EOSQLExpressionPriv.h (_aliasForRelationshipPath:)
(_flattenRelPath:entity:, _aliasForRelatedAttribute:relationshipPath:)
* EOAccess/EOSQLExpression.m (insertStatementForRow:entity:)
(updateStatementForRow:qualifier:entity:)
(deleteStatementWithQualifier:entity:)
(selectStatementForAttributes:lock:fetchSpecification:entity:)
(_aliasForRelationshipPath:)
* EOAccess/EORelationship.h (intermediateEntity)
(_foreignKeyForSourceRow:)
* EOAccess/EORelationship.m (_foreignKeyForSourceRow:, _leftSideKeyMap)
* EOAccess/EODatabaseContext.h (databaseOperationForObject:)
(databaseOperationForGlobalID:, recordDatabaseOperation:)
(_openChannelWithLoginPanel:)
* EOAccess/EODatabaseContextPriv.h (primaryKeyForObject:)
(_currentCommittedSnapshotForObject:)
* EOAccess/EOEntityPriv.h (_keyMapForRelationshipPath:)
(_keyMapForIdenticalKeyRelationshipPath:, _mapAttribute:)
(_relationshipPathIsToMany: valueForSQLExpression:)
(_parsePropertyName:, classPropertyAttributeNames)
(classPropertyToManyRelationshipNames)
(classPropertyToOneRelationshipNames, dbSnapshotKeys)
* EOAccess/EOUtilities.m (rawRowsForEntityNamed:qualifierFormat:)
(rawRowsMatchingValue:forKey:entityNamed:)
(rawRowsMatchingValues:entityNamed:, rawRowsWithSQL:modelNamed:)
(rawRowsWithStoredProcedureNamed:arguments:)
(executeStoredProcedureNamed:arguments:, databaseContextForModelNamed:)
(primaryKeyForObject:)
(destinationKeyForSourceObject:relationshipNamed:)
* EOAccess/EOEntity.m
(_mapAttribute:toDestinationAttributeInLastComponentOfRelationshipPath:)
* EOAccess/EOAdaptor.h (adaptorWithModel:,adaptorWithName:)
* EOAccess/EOModel.h (_classDescriptionNeeded:,_entityForClass:)
(_addEntityWithPropertyList:)
* EOAdaptors/Postgres95/Postgres95Channel.h
(_evaluateExpression:withAttributes:)
* EOControl/EOMutableKnownKeyDictionary.h/m (arrayMappingForKeys:)
(subsetMappingForSourceDictionaryInitializer:sourceKeys:destinationKeys:)
(subsetMappingForSourceDictionaryInitializer:)
(setObject:forKey:, removeObjectForKey:, indexForKey:, objectForKey:)
* EOControl/EOEditingContext.m (handleErrors:,setSharedEditingContext:)
(faultForRawRow:entityNamed:)
* GDL2Palette/KeyWrapper.h (setKey:, _key):
* EOModeler/EOModelerEditor.h (selectionWithinViewedObject)
* EOModeler/EOModelerEditor.m (initWithDocument:)
(initWithParentEditor:)
Correct method signatures. Add necessary forward @class declations.
* EOInterface/EOMasterDetailAssociation.m (establishConnection):
* DBModeler/ModelerTableEmbedibleEditor.m
(addDefaultTableColumnsForTableView:displayGroup:)
* DBModeler/DefaultColumnProvider.m (setupTitleForColumn:named:)
Cast types to avoid compiler warnings.
* EOControl/EOCheapArray.m (dealloc): Supress compiler warning.
* EOAdaptors/Postgres95/LoginPanel/Postgres95LoginPanel.m (dealloc)
* EOModeler/EOModelerEditor.m (dealloc):
* DBModeler/ModelerAttributeEditor.m (dealloc): Add missing call
to super.
* DBModeler/Preferences.m (sharedPreferences): Fix implementation for
new compiler semantics.
* EOControl/EOMultiReaderLock.m (init): Correct NSConditionLock
initialization.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gdl2/trunk@23472 72102866-910b-0410-8b05-ffd578937521
2006-09-12 19:36:24 +00:00
|
|
|
entity: (EOEntity *)entity;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
+ (EOSQLExpression *)selectStatementForAttributes: (NSArray *)attributes
|
2007-01-01 11:52:38 +00:00
|
|
|
lock: (BOOL)flag
|
2002-11-15 22:57:05 +00:00
|
|
|
fetchSpecification: (EOFetchSpecification *)fetchSpecification
|
|
|
|
entity: (EOEntity *)entity;
|
|
|
|
|
2002-12-30 22:10:43 +00:00
|
|
|
+ (id)sqlExpressionWithEntity: (EOEntity *)entity;
|
|
|
|
|
2004-04-17 11:30:47 +00:00
|
|
|
- (id)initWithEntity: (EOEntity *)entity;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
- (NSMutableDictionary *)aliasesByRelationshipPath;
|
|
|
|
- (EOEntity *)entity;
|
|
|
|
|
|
|
|
- (NSMutableString *)listString;
|
|
|
|
- (NSMutableString *)valueList;
|
|
|
|
- (NSMutableString *)joinClauseString;
|
|
|
|
- (NSMutableString *)orderByString;
|
|
|
|
- (NSString *)whereClauseString;
|
|
|
|
- (NSString *)statement;
|
2004-04-17 11:30:47 +00:00
|
|
|
- (void)setStatement: (NSString *)statement;
|
2002-11-15 22:57:05 +00:00
|
|
|
- (NSString *)lockClause;
|
|
|
|
|
|
|
|
- (NSString *)tableListWithRootEntity: (EOEntity *)entity;
|
|
|
|
|
|
|
|
|
|
|
|
- (void)prepareInsertExpressionWithRow: (NSDictionary *)row;
|
|
|
|
|
|
|
|
- (void)prepareUpdateExpressionWithRow: (NSDictionary *)row
|
|
|
|
qualifier: (EOQualifier *)qualifier;
|
|
|
|
|
|
|
|
- (void)prepareDeleteExpressionForQualifier: (EOQualifier *)qualifier;
|
|
|
|
|
|
|
|
- (void)prepareSelectExpressionWithAttributes: (NSArray *)attributes
|
2007-01-01 11:52:38 +00:00
|
|
|
lock: (BOOL)flag
|
2002-11-15 22:57:05 +00:00
|
|
|
fetchSpecification: (EOFetchSpecification *)fetchSpecification;
|
|
|
|
|
|
|
|
- (NSString *)assembleJoinClauseWithLeftName: (NSString *)leftName
|
|
|
|
rightName: (NSString *)rightName
|
|
|
|
joinSemantic: (EOJoinSemantic)semantic;
|
|
|
|
|
|
|
|
- (void)addJoinClauseWithLeftName: (NSString *)leftName
|
|
|
|
rightName: (NSString *)rightName
|
|
|
|
joinSemantic: (EOJoinSemantic)semantic;
|
|
|
|
|
|
|
|
- (void)joinExpression;
|
|
|
|
|
|
|
|
- (NSString *)assembleInsertStatementWithRow: (NSDictionary *)row
|
|
|
|
tableList: (NSString *)tableList
|
|
|
|
columnList: (NSString *)columnList
|
|
|
|
valueList: (NSString *)valueList;
|
|
|
|
|
|
|
|
- (NSString *)assembleUpdateStatementWithRow: (NSDictionary *)row
|
|
|
|
qualifier: (EOQualifier *)qualifier
|
|
|
|
tableList: (NSString *)tableList
|
|
|
|
updateList: (NSString *)updateList
|
|
|
|
whereClause: (NSString *)whereClause;
|
|
|
|
|
|
|
|
- (NSString *)assembleDeleteStatementWithQualifier: (EOQualifier *)qualifier
|
|
|
|
tableList: (NSString *)tableList
|
|
|
|
whereClause: (NSString *)whereClause;
|
|
|
|
|
|
|
|
- (NSString *)assembleSelectStatementWithAttributes: (NSArray *)attributes
|
|
|
|
lock: (BOOL)lock
|
|
|
|
qualifier: (EOQualifier *)qualifier
|
|
|
|
fetchOrder: (NSArray *)fetchOrder
|
|
|
|
selectString: (NSString *)selectString
|
|
|
|
columnList: (NSString *)columnList
|
|
|
|
tableList: (NSString *)tableList
|
|
|
|
whereClause: (NSString *)whereClause
|
|
|
|
joinClause: (NSString *)joinClause
|
|
|
|
orderByClause: (NSString *)orderByClause
|
|
|
|
lockClause: (NSString *)lockClause;
|
|
|
|
|
|
|
|
- (void)addSelectListAttribute: (EOAttribute *)attribute;
|
|
|
|
|
|
|
|
- (void)addInsertListAttribute: (EOAttribute *)attribute
|
|
|
|
value: (NSString *)value;
|
|
|
|
|
|
|
|
- (void)addUpdateListAttribute: (EOAttribute *)attribute
|
|
|
|
value: (NSString *)value;
|
|
|
|
|
|
|
|
+ (NSString *)formatStringValue: (NSString *)string;
|
|
|
|
+ (NSString *)formatValue: (id)value forAttribute: (EOAttribute *)attribute;
|
|
|
|
+ (NSString *)formatSQLString: (NSString *)sqlString
|
|
|
|
format: (NSString *)format;
|
|
|
|
|
|
|
|
- (NSString *)sqlStringForConjoinedQualifiers: (NSArray *)qualifiers;
|
|
|
|
- (NSString *)sqlStringForDisjoinedQualifiers: (NSArray *)qualifiers;
|
|
|
|
- (NSString *)sqlStringForNegatedQualifier: (EOQualifier *)qualifier;
|
|
|
|
- (NSString *)sqlStringForKeyValueQualifier: (EOKeyValueQualifier *)qualifier;
|
|
|
|
- (NSString *)sqlStringForKeyComparisonQualifier: (EOKeyComparisonQualifier *)qualifier;
|
|
|
|
- (NSString *)sqlStringForValue: (NSString *)valueString
|
|
|
|
caseInsensitiveLikeKey: (NSString *)keyString;
|
|
|
|
|
|
|
|
- (void)addOrderByAttributeOrdering: (EOSortOrdering *)sortOrdering;
|
|
|
|
|
|
|
|
+ (BOOL)useQuotedExternalNames;
|
2007-01-01 11:52:38 +00:00
|
|
|
+ (void)setUseQuotedExternalNames: (BOOL)flag;
|
2002-11-15 22:57:05 +00:00
|
|
|
- (NSString *)externalNameQuoteCharacter;
|
|
|
|
|
|
|
|
- (void)setUseAliases: (BOOL)useAliases;
|
|
|
|
- (BOOL)useAliases;
|
|
|
|
|
|
|
|
- (NSString *)sqlStringForSchemaObjectName: (NSString *)name;
|
|
|
|
- (NSString *)sqlStringForAttributeNamed: (NSString *)name;
|
|
|
|
- (NSString *)sqlStringForSelector: (SEL)selector value: (id)value;
|
2007-01-01 11:52:38 +00:00
|
|
|
- (NSString *)sqlStringForValue: (id)value attributeNamed: (NSString *)attributeName;
|
2004-04-17 11:30:47 +00:00
|
|
|
- (NSString *)sqlStringForAttribute: (EOAttribute *)attribute;
|
2002-11-15 22:57:05 +00:00
|
|
|
- (NSString *)sqlStringForAttributePath: (NSArray *)path;
|
|
|
|
|
|
|
|
- (void)appendItem: (NSString *)itemString
|
|
|
|
toListString: (NSMutableString *)listString;
|
|
|
|
|
|
|
|
+ (NSString *)sqlPatternFromShellPattern: (NSString *)pattern;
|
|
|
|
+ (NSString *)sqlPatternFromShellPattern: (NSString *)pattern
|
|
|
|
withEscapeCharacter: (unichar)escapeCharacter;
|
|
|
|
|
|
|
|
|
|
|
|
- (NSMutableDictionary *)bindVariableDictionaryForAttribute: (EOAttribute *)attribute
|
2004-04-17 11:30:47 +00:00
|
|
|
value: (id)value;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
- (BOOL)shouldUseBindVariableForAttribute: (EOAttribute *)att;
|
|
|
|
- (BOOL)mustUseBindVariableForAttribute: (EOAttribute *)att;
|
|
|
|
|
|
|
|
+ (BOOL)useBindVariables;
|
2007-01-01 11:52:38 +00:00
|
|
|
+ (void)setUseBindVariables: (BOOL)flag;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
- (NSArray *)bindVariableDictionaries;
|
|
|
|
- (void)addBindVariableDictionary: (NSMutableDictionary *)binding;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
@interface NSString (EOSQLFormatting)
|
|
|
|
|
|
|
|
- (NSString *)sqlString;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
@interface NSNumber (EOSQLFormatting)
|
|
|
|
|
|
|
|
- (NSString *)sqlString;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
#endif /* __EOSQLExpression_h__ */
|