| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.cayenne.query.AbstractQuery
org.apache.cayenne.query.SQLTemplate
public class SQLTemplate
A query that executes unchanged (except for template preprocessing) "raw" SQL specified by the user.
SQLTemplate stores a dynamic template for the SQL query that supports parameters and customization using Velocity scripting language. The most straightforward use of scripting abilities is to build parameterized queries. For example:
                  SELECT ID, NAME FROM SOME_TABLE WHERE NAME LIKE $a
 
 For advanced scripting options see "Scripting SQLTemplate" chapter in the User Guide.
 SQLTemplate has a default template script, but also it
 allows to configure multiple templates and switch them dynamically. This way a single
 query can have multiple "dialects" specific to a given database.
 
 SQLTemplate supports multiple sets of parameters, so a single query can be executed
 multiple times with different parameters. "Scrolling" through parameter list is done by
 calling parametersIterator(). This iterator goes over parameter sets,
 returning a Map on each call to "next()"
 
| Field Summary | |
|---|---|
| protected  CapsStrategy | columnNamesCapitalization | 
| protected  String | defaultTemplate | 
| protected  Map<String,?>[] | parameters | 
| protected  SQLResult | result | 
| protected  Map<String,String> | templates | 
| Fields inherited from class org.apache.cayenne.query.AbstractQuery | 
|---|
| name, root | 
| Constructor Summary | |
|---|---|
| SQLTemplate()Creates an empty SQLTemplate. | |
| SQLTemplate(Class<?> rootClass,
            String defaultTemplate) | |
| SQLTemplate(DataMap rootMap,
            String defaultTemplate) | |
| SQLTemplate(DbEntity rootEntity,
            String defaultTemplate) | |
| SQLTemplate(ObjEntity rootEntity,
            String defaultTemplate) | |
| SQLTemplate(String objEntityName,
            String defaultTemplate) | |
| Method Summary | |
|---|---|
|  PrefetchTreeNode | addPrefetch(String prefetchPath)Adds a prefetch. | 
|  void | addPrefetches(Collection<String> prefetches)Adds all prefetches from a provided collection. | 
|  void | clearPrefetches()Clears all prefetches. | 
|  Query | createQuery(Map<String,?> parameters)Creates and returns a new SQLTemplate built using this query as a prototype and substituting template parameters with the values from the map. | 
|  SQLAction | createSQLAction(SQLActionVisitor visitor)Calls sqlAction(this) on the visitor. | 
|  void | encodeAsXML(XMLEncoder encoder)Prints itself as XML to the provided PrintWriter. | 
|  String[] | getCacheGroups() | 
|  String | getCachePolicy()Deprecated. since 3.0 getCacheStrategy()replaces this method. | 
|  QueryCacheStrategy | getCacheStrategy() | 
|  CapsStrategy | getColumnNamesCapitalization()Returns a column name capitalization policy applied to selecting queries. | 
|  String | getCustomTemplate(String key)Returns template for key, or null if there is no template configured for this key. | 
|  String | getDefaultTemplate()Returns default SQL template for this query. | 
|  int | getFetchLimit() | 
|  int | getFetchOffset() | 
|  QueryMetadata | getMetaData(EntityResolver resolver)Returns default select parameters. | 
|  int | getPageSize() | 
|  Map<String,?> | getParameters()Utility method to get the first set of parameters, since most queries will only have one. | 
|  PrefetchTreeNode | getPrefetchTree() | 
|  SQLResult | getResult() | 
|  int | getStatementFetchSize() | 
|  String | getTemplate(String key)Returns a template for key, or a default template if a template for key is not found. | 
|  Collection<String> | getTemplateKeys()Returns a collection of configured template keys. | 
|  void | initWithProperties(Map<String,?> properties)Initializes query parameters using a set of properties. | 
|  boolean | isFetchingDataRows() | 
|  boolean | isRefreshingObjects()Deprecated. since 3.0. With introduction of the cache strategies this setting is redundant, although it is still being taken into account. It will be removed in the later versions of Cayenne. | 
|  boolean | isResolvingInherited()Deprecated. since 3.0. Inheritance resolving is not optional anymore. | 
|  Iterator<?> | parametersIterator()Returns an iterator over parameter sets. | 
|  int | parametersSize()Returns the number of parameter sets. | 
|  SQLTemplate | queryWithParameters(Map<String,?>... parameters)Returns a new query built using this query as a prototype and a new set of parameters. | 
|  void | removePrefetch(String prefetch) | 
|  void | removeTemplate(String key) | 
|  void | setCacheGroups(String... cacheGroups) | 
|  void | setCachePolicy(String policy)Deprecated. since 3.0 setCacheStrategy(QueryCacheStrategy)replaces this
             method. | 
|  void | setCacheStrategy(QueryCacheStrategy strategy) | 
|  void | setColumnNamesCapitalization(CapsStrategy columnNameCapitalization)Sets a column name capitalization policy applied to selecting queries. | 
|  void | setDefaultTemplate(String string)Sets default SQL template for this query. | 
|  void | setFetchingDataRows(boolean flag) | 
|  void | setFetchLimit(int fetchLimit) | 
|  void | setFetchOffset(int fetchOffset) | 
|  void | setPageSize(int pageSize) | 
|  void | setParameters(Map<String,?>... parameters)Utility method to initialize query with one or more sets of parameters. | 
|  void | setRefreshingObjects(boolean flag)Deprecated. since 3.0. With introduction of the cache strategies this setting is redundant, although it is still being taken into account. It will be removed in the later versions of Cayenne. | 
|  void | setResolvingInherited(boolean b)Deprecated. since 3.0. Inheritance resolving is not optional anymore. | 
|  void | setResult(SQLResult resultSet)Sets an optional explicit mapping of the result set. | 
|  void | setStatementFetchSize(int size)Sets statement's fetch size (0 for no default size) | 
|  void | setTemplate(String key,
            String template)Adds a SQL template string for a given key. | 
| Methods inherited from class org.apache.cayenne.query.AbstractQuery | 
|---|
| getName, getRoot, route, setName, setRoot, toString | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Methods inherited from interface org.apache.cayenne.query.Query | 
|---|
| getName, route | 
| Field Detail | 
|---|
protected String defaultTemplate
protected Map<String,String> templates
protected Map<String,?>[] parameters
protected CapsStrategy columnNamesCapitalization
protected SQLResult result
| Constructor Detail | 
|---|
public SQLTemplate()
public SQLTemplate(DataMap rootMap,
                   String defaultTemplate)
public SQLTemplate(ObjEntity rootEntity,
                   String defaultTemplate)
public SQLTemplate(Class<?> rootClass,
                   String defaultTemplate)
public SQLTemplate(DbEntity rootEntity,
                   String defaultTemplate)
public SQLTemplate(String objEntityName,
                   String defaultTemplate)
| Method Detail | 
|---|
public QueryMetadata getMetaData(EntityResolver resolver)
AbstractQuery
getMetaData in interface QuerygetMetaData in class AbstractQuerypublic SQLAction createSQLAction(SQLActionVisitor visitor)
createSQLAction in interface QuerycreateSQLAction in class AbstractQuerypublic void encodeAsXML(XMLEncoder encoder)
encodeAsXML in interface XMLSerializablepublic void initWithProperties(Map<String,?> properties)
public Iterator<?> parametersIterator()
public int parametersSize()
public SQLTemplate queryWithParameters(Map<String,?>... parameters)
public Query createQuery(Map<String,?> parameters)
createQuery in interface ParameterizedQuery@Deprecated public String getCachePolicy()
getCacheStrategy() replaces this method.
@Deprecated public void setCachePolicy(String policy)
setCacheStrategy(QueryCacheStrategy) replaces this
             method.
public QueryCacheStrategy getCacheStrategy()
public void setCacheStrategy(QueryCacheStrategy strategy)
public String[] getCacheGroups()
public void setCacheGroups(String... cacheGroups)
public int getFetchLimit()
public void setFetchLimit(int fetchLimit)
public int getFetchOffset()
public void setFetchOffset(int fetchOffset)
public int getPageSize()
public void setPageSize(int pageSize)
public void setFetchingDataRows(boolean flag)
public boolean isFetchingDataRows()
@Deprecated public boolean isRefreshingObjects()
@Deprecated public void setRefreshingObjects(boolean flag)
@Deprecated public boolean isResolvingInherited()
@Deprecated public void setResolvingInherited(boolean b)
public String getDefaultTemplate()
public void setDefaultTemplate(String string)
public String getTemplate(String key)
public String getCustomTemplate(String key)
getTemplate(String)this method does not return a default template
 as a failover strategy, rather it returns null.
public void setTemplate(String key,
                        String template)
setDefaultTemplate(String)public void removeTemplate(String key)
public Collection<String> getTemplateKeys()
public Map<String,?> getParameters()
public void setParameters(Map<String,?>... parameters)
public PrefetchTreeNode getPrefetchTree()
public PrefetchTreeNode addPrefetch(String prefetchPath)
public void removePrefetch(String prefetch)
public void addPrefetches(Collection<String> prefetches)
public void clearPrefetches()
public CapsStrategy getColumnNamesCapitalization()
public void setColumnNamesCapitalization(CapsStrategy columnNameCapitalization)
public void setResult(SQLResult resultSet)
SQLResult rules.
public SQLResult getResult()
public void setStatementFetchSize(int size)
public int getStatementFetchSize()
| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||