Configuring the Search Index
This chapter describes how to configure the Oracle WebCenter Content Server search index. Content Server interfaces with a variety of indexing tools such as commercial search engines and databases.
This chapter includes the following topics:
Variances in Indexing Tools and Methods
Content Server interfaces with a variety of indexing tools such as commercial search engines and databases. The indexing tool to use is chosen before installation based on the purpose and environment in which the Content Server instance performs.
Each indexing tool provides full-text indexing and metadata-only indexing. Full-text indexing means that every word in a file is indexed, not only its metadata. Full-text indexing takes longer than metadata indexing; however, it can return a more comprehensive result set. Metadata-only indexing means that every word in the stored content information is indexed. Metadata-only indexing is faster than full-text indexing. By default the Content Server instance is configured to use metadata-only indexing.
Configuring the Search Index for Databases
If your system is set up to provide indexing and searching capabilities with databases, your system integrator would have added one of the following lines in the IntradocDir/config/config.cfg file:
- 
    Metadata Searching Only: SearchIndexerEngineName=DATABASE.METADATADATABASE.METADATA is supported in all databases supported by Oracle Fusion Middleware 12c release. 
- 
    Full-text Searching: SearchIndexerEngineName=ORACLETEXTSEARCHORACLETEXTSEARCH is supported in Oracle Database version 11.1.0.7 and newer. 
- 
    Full-text Searching: SearchIndexerEngineName=DATABASE.FULLTEXTDATABASE.FULLTEXT is supported in SQL Server, and in Oracle Database (all supported versions). The dbfulltextsearchscript appropriate for the supported database would then be run.- 
        By default, full-text indexing is applied to all converted files. 
- 
        By default, the Content Server full-text indexes files that are passed through or converted to any of the following formats: Oracle Supported Formats - 
            pdf 
- 
            html 
- 
            htm 
- 
            xls 
- 
            hcsp 
- 
            text 
- 
            txt 
- 
            doc 
- 
            rtf 
- 
            ppt 
 MS SQL Supported Formats - 
            text 
- 
            txt 
- 
            htm 
- 
            html 
- 
            doc 
- 
            msword 
- 
            ms-word 
- 
            ms-powerpoint 
- 
            ppt 
- 
            ms-excel 
- 
            xls 
 For example, if you want to convert your Microsoft Word ( .doc) files to text files instead of PDF, you can specify this with the Configuration Manager. That is, when you use the File Formats option to map the.docfile extension to a text format, then this defines how the file is converted to a web-viewable format. In this case, the text file is fully indexed before it is passed to the website.See Managing Native Content Conversion in Managing Oracle WebCenter Content. 
- 
            
- 
        You can enable contributors to specify whether to full-text index a file by enabling the format override feature with the System Properties utility. See Configuring General Options. For example, if you have used the Configuration Manager’s File Formats option to map Corel WordPerfect (.wpd) files to use a text format and a contributor selects the use default option in the Format field on the check-in page, the file will be converted to text and full-text indexed. If the contributor selects Corel WordPerfect Document,**the file will be passed through in its native format and will not be full-text indexed.
- 
        When you use full-text searching, a search is case sensitive for metadata, and case insensitive for full text. For Content ID, however, lowercase letters are converted to uppercase letters, so Content ID cannot be searched with lowercase letters. 
 
- 
        
Note:
To avoid errors when indexing, do not add non-existent metadata fields to the Configuration Manager DrillDownFields parameter, and do not add memo fields to an SDATA section or to the DrillDownFields parameter. See Metadata Fields in Developing with Oracle WebCenter Content.
The following sections provide instructions for additional search index configurations:
Configuring Metadata Search with All Databases
To set up and use metadata-only searching and indexing in all databases:
- 
    Ensure that Content Server is installed and configured to work with the database. 
- 
    Add the following entry to the DomainHomeName/ucm/cs/config/config.cfgfile and save the file:SearchIndexerEngineName=DATABASE.METADATA
- 
    Restart the Content Server instance. 
Configuring Full-Text Search with SQL Server
To set up and use full-text database searching and indexing in SQL Server and in Oracle Database (all supported versions):
- 
    Ensure that Content Server is installed and configured to work with the database. 
- 
    Add the following entry to the DomainHomeName/ucm/cs/config/config.cfgfile and save the file:SearchIndexerEngineName=DATABASE.FULLTEXT
- 
    Restart the Content Server instance. 
- 
    Rebuild the search index using the Repository Manager. - 
        To access the Repository Manager, choose Administration, then Desktop Client Apps, then Repository Manager. 
- 
        Click Start in the Collection Rebuild Cycle part of the Indexer tab. The search index is entirely rebuilt, and the old index collection is replaced with a new index collection when the rebuild is successfully completed. 
 
- 
        
Configuring Full-Text Search with OracleTextSearch
To set up and use full-text searching and indexing with OracleTextSearch, which is supported in Oracle Database version 11.1.0.7 and newer:
- 
    Ensure that Content Server is installed and configured to work with the database. 
- 
    Add the following entry to the DomainHomeName/ucm/cs/config/config.cfgfile and save the file:SearchIndexerEngineName=ORACLETEXTSEARCH
- 
    Restart the Content Server instance. 
- 
    Rebuild the search index using the Repository Manager. - 
        To access the Repository Manager, choose Administration, then Desktop Client Apps, then Repository Manager. 
- 
        Click Start in the Collection Rebuild Cycle part of the Indexer tab. The search index is entirely rebuilt, and the old index collection is replaced with a new index collection when the rebuild is successfully completed. 
 
- 
        
For more information on OracleTextSearch, see Managing OracleTextSearch.
Optimizing Full Text Search
When using full text search in WebCenter Content, with either of the following two settings, the database uses Oracle Text Index to manage the data for searching.
SearchIndexerEngineName=OracleTextSearch
SearchIndexerEngineName=DATABASE.FULLTEXT
When using Oracle Text Index, the index on the database must be maintained in order to keep the disk from becoming fragmented. To avoid fragmentation, an optimize_index procedure should be run weekly. This procedure should be scheduled by the database administrator for WebCenter Content.
Determine the Active Index
To determine what is the active index on your WebCenter Content system, log in to the WebCenter Content system and select Administration, then Configuration for instance. On the Configuration page, for Oracle Text Search you will see something like the following information:
Search Engine::ORACLETEXTSEARCH
Index Engine Name:ORACLETEXTSEARCH
Active Index:ots2
For full text database, you will see something like the following information:
Search Engine::DATABASE.FULLTEXT
Index Engine Name:DATABASE.FULLTEXT
Active index:IdcColl1
The Active Index values tell you the table and index active in the database.
| SearchIndexerEngineName | Active Table | Database Table | Database Index | 
|---|---|---|---|
| OracleTextSearch | ots1 | IDCTEXT1 | FT_IDCTEXT1 | 
| OracleTextSearch | ots2 | IDCTEXT2 | FT_IDCTEXT2 | 
| DATABASE.FULLTEXT | IdcColl1 | IDCCOLL1 | FT_IDCCOLL1 | 
| DATABASE.FULLTEXT | IdcColl2 | IDCCOLL2 | FT_IDCCOLL2 | 
Determine if Oracle Text Index Needs Optimization
To determine if an Oracle Text Index is fragmented and possibly in need of optimization, a report called INDEX_STATS from the CTX_REPORT package can provide a useful view into the WebCenter Content indexes used for Oracle Text Search. For information on the CTX_REPORT package, see the Oracle Text Reference Guide.
Implement the optimize_index Procedure
Request that the database administrator schedule a job on the database to run the optimize_index procedure weekly (usually best run on weekends or whenever usage is lower) or as needed based on the database administrator’s recommendation. The parameters can be tuned as needed in the call to the procedure, but the default execution uses the parameters in this example:
begin
CTX_DDL.OPTIMIZE_INDEX('FT_IDCTEXT1','FULL',parallel_degree=>'1');
end;
In some cases, running the optimize_index procedure for the first time can cause a large amount of redo logs to be created on the database. If optimize_index cannot complete, or the log files on the database are filling up, restart the database in NOARCHIVELOG mode and run the optimize_index procedure. When the optimization procedure is complete, restart the database in ARCHIVELOG mode.
Configuring Database-Supported File Formats
If you define a file format to PASSTHRU in the native format, and the format name contains one of the types listed above (such as application/ms-excel.native), the passed through native file will be full-text indexed by default.
Alternatively, you can use configuration variables to control whether a document is full-text indexed. To manage the full-text indexing and search of specific document format types, add applicable entries to IntradocDir/config/config.cfg and save the file. Full-text indexing configuration variables include:
FormatMap
The FormatMap configuration variable controls whether files of a specific format should be included in the full-text search index. It is a comma-delimited list of all the formats that will be full-text indexed. The decision is made by taking the MIME type assigned to a file, splitting the MIME type apart at any slash (/) or period (.), and then checking if that value is in the FormatMap list.
For example, application/vnd.msword will turn into a list of three items:
- 
    application 
- 
    vnd 
- 
    msword 
If FormatMap has msword in its list, then the indexer engine will attempt to full-text index the file. the comparison test is not case sensitive.
ExceptionFormatMap
The ExceptionFormatMap configuration variable is used to exclude document formats from the FormatMap test. Any format that satisfies the ExceptionFormatMap test will not be full-text indexed. This test is done after splitting the MIME format at slashes (/), but not periods(.). For example, if msword is included in the exceptions list, then the MIME format application/msword is excluded but not application/vnd.mssword.
Modifying Default Indexing
Depending on the search engine used, Content Server indexes metadata only or both metadata and the content item’s full-text. By default, full-text indexing is performed based on the file format of the content item and several other file-related considerations.
Before a content item is forwarded to the search index, Content Server executes the std_indexable_format_script resource. To modify the default indexing criteria, you can create a custom component to modify the std_indexable_format_script resource. For example, you can selectively include or exclude full-text indexing for content items based on their MIME types or based on the value of any metadata field, including custom metadata fields.
This section cover the following topics:
See Creating Custom Components in Developing with Oracle WebCenter Content.
Indexing Resource Defaults
The default script for the std_indexable_format_script resource is as follows:
<@dynamichtml std_indexable_format_script@>
 
<$loop DocIndexableFormats$>
<$if DocIndexableFormats.fileSize <= MaxIndexableFileSize and
 DocIndexableFormats.fileSize >= MinIndexableFileSize$>
   <$indexableFilePath = DocIndexableFormats.filePath$>
   <$indexableFileSize = DocIndexableFormats.fileSize$>
   <$indexableFileURL = DocIndexableFormats.url$>
   <$if isFalse(DocIndexableFormats.allowDirectIndex) and
    isTrue(DocIndexableFormats.allowConversion)$>
      <$indexerConversionHandler = DocIndexableFormats.conversionHandler$>
   <$endif$>
   <$if isTrue(DocIndexableFormats.useMap)$>
      <$indexerUseMap = "1"$>
      <$indexerMapExtension = DocIndexableFormats.mapExtension$>
   <$endif$>
   <$break$>
<$endif$>
<$endloop$>
<@end@>
The script compares the content item to the list of indexable formats. If it finds a match, it determines whether the file is within established size boundaries and sets a number of index-related values for the content item.
Indexing Resource Include Example
Scenario 1:
When a user checks in specific document types, they can choose to either index the content item using metadata only or using both metadata and full text.
Solution 1:
To allow users to specify whether a document is indexed using metadata only or using both metadata and full text, you can create a custom metadata field (for example, xIsFullTextSearchable) with a list that has two values: Yes and No with Yes as the default. When a user checks in a document that contains accounting data and, therefore, should not be indexed using full text, they set the value of xIsFullTextSearchable to No.
To implement this solution, create a custom component that encloses the default resource code in a new IF statement that checks the value of the custom field:
<@dynamichtml std_indexable_format_script@>
 
<$if strEquals(xIsFullTextSearchable, "Yes")$>
<$loop DocIndexableFormats$>
    .
    .
    .
<$endloop$>
<$endif$>
<@end@>
Scenario 2:
Do not perform a full-text index for web-viewable renditions of content items that are themselves indexed.
Solution 2:
To implement this solution, create a custom component that encloses the default resource code in a new IF statement that checks the value of FormatType to determine if the item is a native file (FormatType="vault") or a web-viewable rendition (FormatType="webviewable"):
<@dynamichtml std_indexable_format_script@>
 
<$if strEquals(FormatType, "vault")$>
<$loop DocIndexableFormats$>
    .
    .
    .
<$endloop$>
<$endif$>
<@end@>
Working with the Search Index
This section covers these topics:
About the Search Index
The Repository Manager utility provides an Indexer tab which administrators can use to perform actions on the search index.
To access the Repository Manager, choose Administration, then Desktop Client Apps, then Repository Manager. You can also access the Repository Manager as a standalone application. For details, see Running Administration Applications in Standalone Mode.
The Indexer tab on the Repository Manager window enables administrators to perform these actions:
- 
    Update the Search Index: Incrementally updates the index database. This is usually not necessary because the index is automatically updated approximately every five minutes by the server. 
- 
    Rebuild the Collection: The search index is entirely rebuilt, and the old index collection is replaced with a new index collection. 
- 
    Suspend an Update or a Rebuild: Stops the update or rebuild temporarily. You can restart the process by clicking the appropriate Start button. 
- 
    Cancel Update Search: Index update process terminates, and only files processed to that point are accessible to the search engine. 
- 
    Cancel Rebuild Collection: Index rebuild process terminates, and the previous index database continues to be used by the search engine. 
See Managing Content in Managing Oracle WebCenter Content.
Updating the Search Index
- 
    In the Repository Manager window, click the Indexer tab. 
- 
    Click Start in the Automatic Update Cycle area. 
Rebuilding the Collection
- 
    In the Repository Manager window, click the Indexer tab. 
- 
    Click Start in the Collection Rebuild Cycle area. 
Note:
OracleTextSearch provides a Fast Rebuild function, which you can use through the Repository Manager Indexer function if your site uses the OracleTextSearch feature. For details, see Fast Rebuild.
Configuring the Search Index Update or Collection Rebuild
To set the parameters for a search index update or collection rebuild:
- 
    In the Repository Manager window, click the Indexer tab. 
- 
    Click Configure in either the Automatic Update Cycle portion of the screen or the Collection Rebuild Cycle portion. Either the Automatic Update Cycle window or the Collection Rebuild Cycle window opens. 
- 
    Specify the number of content items (files) per indexer batch. This is the maximum number of files that the search index will process simultaneously. The default is 25. For example, 25 files are indexed together, then the next 25 files are indexed. However, if one item fails, then the batch is processed again. 
- 
    Specify the content items (files) per checkpoint. This is the number of files that will go through all relevant indexing states at a time. You can have multiple batches of files indexed per checkpoint. 
- 
    Specify the indexer debug level. This is the amount of information pertaining to each file to display in the server window. The more debug information is listed in the server window, the slower the indexing progresses. The levels include: - 
        none: No information for each file access is displayed, and no log will be generated. 
- 
        verbose: Displays information for each file accessed. Indicates indexed, ignored, or failed, and generates a full report. 
- 
        debug: Displays the medium level of information, which is specifically functional. 
- 
        trace: Displays the lowest level of information for each activity performed. 
- 
        all: Displays the highest level of debug information. 
 
- 
        
- 
    If you selected Automatic Update Cycle, the Indexer Auto Updates check box is available. Select this if you want the index database to be updated automatically. 
- 
    Click OK. 
Full-Text Indexing
If you have configured the Content Server instance to use DATABASE.FULLTEXT or ORACLETEXTSEARCH as your indexing engine, Content Server uses the Outside In Content Access module to export content to a text file upon check-in. The text file is then passed to the full-text indexer for full-text indexing.
Note:
When the Outside In Content Access module converts a PostScript file, the conversion process produces text that contains extra characters. Unfortunately, this creates a file that is full-text indexed but cannot be full-text searched.
If you use DATABASE.FULLTEXT, a full-text search can be problematic on large documents. By default, the maximum document size that is indexed is 10MB. This can be changed by setting the MaxIndexableFileSize configuration variable in the Content Server repository. The default is MaxIndexableFileSize=10485760. If larger documents require full-text indexing, the value of MaxIndexableFileSize should be increased.
For information on optimizing your search collection when you are using full-text searching with the Oracle database, which would apply to both OracleTextSearch and DATABASE.FULLTEXT search methods, see Optimizing Full Text Search and also Full-text indexing? You must read this.
Disabling Full-Text Indexing
You might want to disable full-text indexing if, for example, you want to conserve file space or if you do not require full-text searching for specific content types. Even if you disable full-text indexing, metadata is still indexed.
To disable full-text indexing on specific files:
- 
    Define a format named application/noindex on the Configuration Manager page. 
- 
    Enable the Allow Override Format on Check In setting. For more information, see Configuring General Options. 
- 
    When a user checks in a file that they do not want to be indexed, they should select the application/noindex format. This applies to standard files, batch loads, and archived revisions. 
Indexing Native Files by Default
The search index uses weblayout files for indexing by default. In certain situations it may be useful to index native files by default instead of weblayout files. For example, if a converted PDF file cannot be extracted and indexed because of processing issues, the native Word document or an alternate type of document could be extracted and indexed. Another example is if the primary file cannot be indexed because it is an .exe file, but it has an alternate .txt file, then the alternate file could be indexed.
To have the search index use native files for indexing by default, set the following parameter in the Content Server instance:
UseNativeFormatInIndex=true
Indexing Email and Attachments
Content Server supports indexing of email and email attachments (such as original files and zip files). Email messages are indexed by default, and if a message contains an attachment it is extracted and indexed as full text. There is no change on what gets returned on search result: if a search finds information in a document, the document metadata is returned. All email attachments supported by Outside In Technology are supported by the search index.
Managing Zone Text Fields
The functionality described in this section is only available if you have installed and enabled the Database Search Contains Operator feature.
Note:
This feature is not required in the OracleTextSearch component.
This section covers these topics:
About Zone Text Fields
The Database Search Contains Operator feature enables you to use the Contains search operator to search text fields when performing Database and Database Full Text searches on SQL Server and Oracle. You must first enable the text fields that can be queried using the Contains search operator. These text fields are called zone text fields.
When a text field is added as a zone text field, the text within the field is parsed and a full‐text index for the field is created in the database. The database performs all the work of creating the index, and the index is dropped from the database if the text field is disabled as a zone text field. Therefore, there is no need to rebuild the collection after enabling or disabling text fields as a zone text fields.
Important:
Changing a text field to a zone text field can be a very time-consuming operation. The amount of time it takes to parse the text and create the full-text index depends on the number of content items in the Content Server repository and the amount of text stored in the text field. However, after the text field has been indexed, you should not experience significant performance issues when updating and adding content items.
When a text field has been enabled as a zone text field, the CONTAINS search operator is available for the text field on the Advanced Search page. It is represented as the Has Word option in the list next to the text field.

Enabling and Disabling Zone Text Fields
Note:
The functionality described here is only available if you have installed and enabled the Database Search Contains Operator feature. The zone text fields feature is not required in the OracleTextSearch component.
When enabling and disabling zone text fields, consider the following:
- 
    Custom text fields (the Comments field and any customer created text fields) are shared between the Database and Database search engines, and therefore changing the status of these text fields for one search engine also applies the changes to the other search engine. 
- 
    Standard text fields (Author, Content ID, Content Type, Title, and so on) can be enabled or disabled independently for each search engine. 
- 
    The database performs all the work of creating the indexes, and the index are dropped from the database if the text fields are disabled as zone text fields. Therefore, there is no need to rebuild the collection after enabling or disabling text fields as a zone text fields. 
- 
    You must disable a zone text field before the field can be deleted from the Content Server instance using Configuration Manager. If you delete an enabled zone text field using Configuration Manager and then click Update Database Design, you will receive an error. Disabling the zone text field drops the index for the field from the database, allowing the field to be deleted from the database. As an alternative to disabling the zone text field, you could log in to the database and issue a command to drop the index for the field, and then delete the field. 
- 
    You might want to disable all zone text fields before uninstalling the feature. Otherwise, you are not able to delete the zone text fields from the Content Server instance unless you reinstall the feature to disable the zone text fields or drop the indexes for the zone text fields from the database manually. 
To enable and disable zone text fields:
- 
    Choose Administration, then Zone Fields Configuration.  Note: Custom text fields (the Comments text field and any customer‐created text fields) are shared between the Database and DatabaseFullText search engines. Therefore, changing the status of these text fields for one search engine also applies the changes to the other search engine. Standard text fields (Author, Content ID, Content Type, Title, and so on) can be enabled or disabled independently for each search engine. 
- 
    In the Zone Fields Configuration window, select the search engine to be used to search the zone text fields (either DatabaseorDatabaseFullText).
- 
    To enable text fields as zone text fields: - 
        Select the text fields (for the selected search engine) in the Text Fields list. You can press the Ctrl and Shift keys on your keyboard to select multiple fields. By default, text fields with a field length of 20 characters or less are not included in the Text Fields list. You can change this setting by modifying the MinFullTextFieldLengthconfiguration variable. For details, see Changing the Minimum Length of Text Fields.
- 
        Click the left arrow button to move the text fields to the Zone Text Fields list. 
- 
        Click Update. This action enables the text fields in the Zone Text Fields list as zone text fields, and disables text fields in the Test Field list. This action also parses the text within all zone text fields and creates a full-text index that can be queried using the Containssearch operator.Important: Changing a text field to a zone text field can be a very time-consuming operation. The amount of time it takes to parse the text and create the full‐text index depends on the number of content items in the Content Server repository and the amount of text stored in the text field. However, when the text field has been indexed, you should not experience significant performance issues when updating and adding content items. 
 
- 
        
- 
    To disable zone text fields: - 
        Select the zone text fields in the Zone Text Fields list. You can press the Ctrl and Shift keys on your keyboard to select multiple fields. 
- 
        Click the right arrow button to move the text fields to the Text Fields list. 
- 
        Click Update. 
 
- 
        
- 
    If you start making changes to the lists and you then want to revert to the last saved lists, click Reset. 
Changing the Minimum Length of Text Fields
Note:
The functionality described here is only available if you have installed and enabled the Database Search Contains Operator feature. The zone text fields feature is not required in the OracleTextSearch component.
By default, text fields with a field length of 20 characters or less are not included in the Text Fields list. You can change this setting by modifying the MinFullTextFieldLength configuration variable. To change this variable:
- 
    Using a text editor, open the config.cfgfile located in theIntradocDir/config/directory.
- 
    Add the MinFullTextFieldLengthconfiguration variable, and set its value (the default value is 21). For example:MinFullTextFieldLength=16
- 
    Save your changes to the config.cfgfile.
- 
    Restart the Content Server instance. 
Disabling Database Search Contains Operator
Note:
The functionality described here is only available if you have installed and enabled the Database Search Contains Operator feature. The zone text fields feature is not required in the OracleTextSearch component.
Before disabling the Database Search Contains Operator feature, you might want to disable all zone text fields. The database contains an index for each enabled zone text field (the indexes are dropped when the zone text fields are disabled). If the database contains an index for a field, it will not let you delete the field from your Content Server instance using Configuration Manager. For more information, see Enabling and Disabling Zone Text Fields.
If you disable the feature and later want to delete a field that is enabled as a zone text field, you can use one of the following options:
- 
    Reinstall the feature, disable the zone text field, use Configuration Manager to delete the field, and uninstall the feature. 
- 
    Log in to the database and issue a command to drop the index for the field, then use Configuration Manager to delete the field. 
Searching Content Using Oracle Query Optimizer
The OracleQueryOptimizer component is installed (enabled) by default with the Content Server instance. The functionality only works with the Oracle database.
This section covers these topics:
About Oracle Query Optimizer
Oracle database does not automatically select the best execution plan for certain types of user queries. To counter this, the Oracle Query Optimizer adds hints to queries that force Oracle database to perform searches more efficiently.
The hints are based on an intrinsic knowledge of Content Server table data distribution and its index selectivity. To take advantage of this knowledge, Oracle Query Optimizer uses a pre-defined Hint Rules Table to analyze the database query and then add appropriate hints to the query. In turn, the added hints improve Oracle’s search performance.
Oracle Query Optimizer takes advantage of Content Server data distribution in database tables and its index selection preferences. Based on these characteristics, the Hint Rules Table included with Oracle Query Optimizer contains pre-defined rules. The feature uses these rules to analyze a database query and to add one or more appropriate hints to the query to optimize the search performance.
In very large collections containing millions of content items, the Content Server software generally has a difficult time selecting an appropriate optimization strategy to resolve even simple queries. To counteract this problem, Oracle Query Optimizer examines the submitted query and, based on its analysis, reformats the query by adding appropriate hints to optimize the search process. To add hints, the feature uses Content Server hints, the Hint Rules TableHint Rules Table, and the Hint Cache.
Query Optimization Process
The stages of the optimization process are completed in the following sequence:
- 
    The submitted query is analyzed to verify if it contains one or more hints and, if so, determine the type of hint. For more information, see Stage 1: Query Analysis. 
- 
    If the query’s WHERE clause does not contain a hint, the optimization feature must parse out the WHERE clause. For more information, see Stage 2: Parsing. 
- 
    After parsing, each condition in the query’s WHERE clause is evaluated against the Hint Rules Table in an attempt to qualify the condition and normalize the query. For more information, see Stage 3: Normalization. 
- 
    After the WHERE clause conditions are qualified and the query is normalized, a hint is selected or retrieved from the hint cache. For more information, see Stage 4: Select Hint. 
- 
    The query is reformatted using the selected hint. For more information, see Stage 5: Reformat Query. 

Stage 1: Query Analysis
In this stage, a query is checked for both Oracle (native) and Content Server hints. This is determined based on the hint syntax: Query Hints Syntax. A query that contains Oracle hints is passed through. A query that contains Content Server hints bypasses Stage 2: Parsing and Stage 3: Normalization. If a query contains multiple Content Server hints, the best hint is chosen. Queries that do not contain any hints must be parsed and normalized.
Stage 2: Parsing
In this stage, a query that does not contain any hints is sent through the query parser and the WHERE clause is parsed out. A WHERE clause consists of one or more conditions joined with either AND or OR conjunctions. For each condition, the field name, operator, and field value are extracted. The AND/OR conjunctions of the clause are preserved; the parentheses are dropped. Conditions must use the following format:
*`fieldname`* *`operator`* *`value`*
For example, a properly formatted condition would be dID = 3. An incorrect condition would be 3 = dID.
Stage 3: Normalization
In this stage, normalization simplifies conditions, finalizes query operators, and provides a stable view of the WHERE clause for additional steps. The result of the normalization process produces a base for generating the cache key and the list of fields to use to search for hints.
Note:
To establish which database tables and columns have indexes, the Hint Rules Table is defined on Content Server resources and on the running system.
- 
    Qualifying WHERE Clause Conditions: Each condition in the WHERE clause is checked against the Hint Rules Table. If a condition’s field name is included in the Hint Rules Table, then it is qualified and the condition is considered to be normalized. The condition contains its table name and alias. Then the normalized conditions are sorted to ensure that the same set of conditions is always listed consistently. 
- 
    Discarding WHERE Clause Conditions During Normalization: During normalization, the following conditions are not considered relevant and are eliminated from further processing: - 
        Join conditions. 
- 
        Conditions that contain subqueries. 
- 
        Conditions whose field names do not have entries in the Hint Rules Table and cannot be qualified. 
- 
        OR conditions that contain more than one field. For example: (dSecurityGroup = 'Secure' or dDocAccount LIKE 'prj%')
- 
        Conditions that contain the LIKE operator whose value begins with a wildcard. 
 
- 
        
- 
    Reformatting WHERE Clause Conditions: In the normalization step, the query conditions are rewritten to consolidate complex query conditions. OR conditions are reevaluated as follows: - 
        If all the fields are the same and all the operators are equal (or all the operators are LIKE and no values begin with a wildcard), the conditions are combined and changed to an IN query. 
- 
        If the fields are the same but have different operators, the conditions are combined and the generic operator is assigned. 
- 
        If the fields are different, the conditions are dropped. 
 For example, during normalization, the following condition is reformatted: `(`dReleaseState = 'Y' OR dReleaseState = 'O")It is reformatted as follows: dReleaseState IN ('Y', 'O')
- 
        
- 
    Finding Potential Range Queries: The parsed query is analyzed to find potential range queries that are then consolidated during the normalization process. For example, the conditions dIndate > date1anddInDate < date2are changed to one condition with the operator ‘range’.
Stage 4: Select Hint
In this stage, the normalized conditions are checked against the hint cache. If one or more conditions have applicable hints in the cache, they are included. If applicable hints are not found in the cache, the conditions are analyzed and the preference orders are compared to determine the best possible hint.
Stage 5: Reformat Query
In this stage, the query is reformatted by adding in the selected hint. For more information about how reformatting queries with hints helps to optimize searches and some examples of reformatted queries, see How Reformatted Queries Optimize Searches.
How Reformatted Queries Optimize Searches
The majority of queries in a Content Server instance involve a small, targeted set of content items or return a hundred rows, at most. Content Server software can easily scale to millions of content items. However, testing on an Oracle database with a collection containing 10 million content items indicates that the execution plan that Oracle selects is not the most efficient. Oracle generally does not choose the best optimization strategies to resolve many queries, even some that are trivial. The following examples explain this issue:
Example 1: Reformatting a Query by Adding a Single Hint
In the environment described above, Oracle does not resolve the following query as efficiently as possible:
SELECT *
FROM Revisions, Documents, DocMeta
WHERE Revisions.dID = Documents.dID
    AND Revisions.dID = DocMeta.dID
    AND Revisions.dRevClassID = 333
Order By Revisions.dID
Because a fairly selective index is available (dRevClassID_2 for Revisions.dRevClassID), this query should access dRevClassID_2 and perform a sort on the rows that match the dRevClassID. However, in this query example, Oracle chooses to use the Revisions.dID index.
This choice is actually worse than performing a full table scan on the Revisions table because it does a full index scan and accesses the table to obtain the dRevClassID for each row. Obviously, resolving the query using this execution plan does not work well when the Content Server repository has over 10 million content items. In this case, it requires approximately 500 seconds to return the results.
However, the performance improves dramatically when the query is modified by adding a hint as follows:
SELECT /*+ INDEX(Revisions dRevClassID_2)*/ *
FROM Revisions, Documents, DocMeta
WHERE Revisions.dID = Documents.dID
    AND Revisions.dID = DocMeta.dID
    AND Revisions.dRevClassID = 333
Order By Revisions.dID
The query is modified by adding the following hint to the SELECT clause:
`/*+ INDEX(Revisions dRevClassID_2)*/`
This forces Oracle database to choose the dRevClassID_2 index instead of the index for Revisions.dID. Because no more than a few content items share dRevClassID in this example, the modified query returns the results instantly.
Example 2: Reformatting a Query by Adding Multiple Hints
In a typical Content Server instance, most documents have a ‘Y’ (released) status for the dReleaseState with a dInDate earlier than the current date. However, only a few documents have a ‘N’ (new, not yet indexed) status for the dReleaseState. The following query is searching for content items that have not yet been released:
SELECT dID
FROM Revisions
WHERE Revisions.dReleaseState = N'N' AND Revisions.dStatus in
    (N'DONE', N'RELEASED', N'DELETED')
    AND Revisions.dInDate<={ts '2005-02-23 17:46:38.321'}
The optimized result for the query uses the index for dReleaseState:
SELECT/*+ LEADING(Revisions) INDEX (Revisions dReleaseState)*/
    dID
FROM Revisions 
WHERE Revisions.dReleaseState = N'N' AND Revisions.dStatus in
    (N'DONE', N'RELEASED', N'DELETED')
    AND Revisions.dInDate<={ts '2005-02-23 17:46:38.321'}
Types of Recognized Hints
Content Server queries can be static queries defined in various resources, data sources with additional dynamic WHERE clauses, and dynamic queries that are ad-hoc or defined in the application such as Archiver. Static queries can be updated with Oracle database hints. However, it is nearly impossible to predefine hints for ad-hoc queries and dynamic WHERE clauses.
Content Server hints use a database-neutral hint syntax that supports multiple hints in the same query. A Content Server hint can be used in any query, data source, and WHERE clause. However, it cannot be combined with an Oracle database hint. If a query contains both types of hints, Oracle Query Optimizer will retain the Oracle database hint and ignore the Content Server hint.
Query Hints Syntax
During the optimization processing stages, Oracle Query Optimizer recognizes the distinct syntaxes of both types of hints and correspondingly processes the submitted query. For more information on the optimization process, see Query Optimization Process.
Oracle Hint Syntax
An Oracle hint uses the following format:
/*+ *`hint`* */
For example:
/*+ Index(Revisions dID)*/
Content Server Hint Syntax
The Content Server hint syntax is database neutral and can support multiple Content Server hints in the same query. During the optimization process, Content Server hints are evaluated and the best hints are formatted and added back to the query.
During the optimization process, a query that includes one or more Content Server hints is not parsed. Only Content Server hints are considered when choosing indexes.
- 
    Content Server Hint Syntax: When a query undergoes the optimization process, Content Server hints are added to the reformatted query using the following syntax: /*$*`tableName`*[ *`aliasName`*]:*columnName*[:*operator* [:*<value\>*]][, …]*/Where: - 
        Values enclosed in angle brackets (<value>) are required. 
- 
        Values enclosed in brackets ([value]) are optional. 
- 
        Ellipses (…) indicates a repetition of the previous expression(s). 
 
- 
        
- 
    Query Before Optimization Process: SELECT * FROM Revisions, DocTypes, RoleDefinition WHERE /*$Revisions:dStatus*/(Revisions.dStatus<>'DELETED' AND Revisions.dStatus<>'EXPIRED' AND Revisions.dStatus<>'RELEASED') AND Revisions.dDocType = DocTypes.dDocType AND /*$Revisions:dReleaseState*/Revisions.dReleaseState<>'E' AND (Revisions.dSecurityGroup = RoleDefinition.dGroupName AND RoleDefinition.dRoleName = ? AND RoleDefinition.dPrivilege > 0
- 
    Reformatted Query with Content Server Hints Added: After the query has undergone the optimization process, both indexes are used and are added to the native indexes. SELECT/*+ LEADING(revisions) INDEX (revisions dStatus dReleaseState)*/ * FROM Revisions, DocTypes, RoleDefinition WHERE (Revisions.dStatus<>'DELETED' AND Revisions.dStatus<>'EXPIRED' AND Revisions.dStatus<>'RELEASED') AND Revisions.dDocType = DocTypes.dDocType AND Revisions.dReleaseState<>'E' AND (Revisions.dSecurityGroup = RoleDefinition.dGroupName AND RoleDefinition.dRoleName = ? AND RoleDefinition.dPrivilege > 0)
Additional Supported Sort Constructs
Using Oracle sort constructs in search query clauses allows users greater flexibility when performing a query. Sort constructs specify the row data in two or more tables to be extracted, sorted, and combined. Essentially, the sort constructs serve the purpose of limiting the number of rows that are returned. Oracle Query Optimizer recognizes the following sort constructs:
- 
    Group by: Sorts a set of records and specifies how to group the results. 
- 
    Order by: Sorts a set of records and specifies whether the results are to be returned in ascending or descending order. 
- 
    Inner join: Sorts a set of records by looking for and returning those that match. 
- 
    Outer join: Sorts a set of records by looking for and returning those that do not match. 
Hint Rules Table
The Hint Rules Table contains the rules that the optimization feature uses to determine the proper hints to add to dynamic queries or data sources during the optimization process. Using the Edit Hint Rules form, a hint rule can be defined for a particular field and operator. A hint rule can also be defined based on values or date/number ranges. The hint rule table is extensible by other components, and can be updated while the Content Server instance is running.

Several default hint rules included with Oracle Query Optimizer are described in the following text. For more detailed descriptions of the table columns, see Hint Rules Table. The content of the Hint Rules Table is available on the Hint Rules Configuration page that is accessed through the Administration tray.
The Hint Rules Table is scheduled to reload every night, and when a rule is added or modified. The hint value is recalculated at each reload.
Important:
Although the Hint Rules Table includes a column allowing multiple indexes to be used with each other, in Oracle only the bitmap index can be combined. This is because the Hint Rules Table was designed for core Content Server functionality.
Therefore, it might not be sufficient for a system with components that create additional tables or add additional metadata fields, or both. However, the Hint Rules Table can be extended or overwritten by other components to provide knowledge of additional tables, indexes and fields.
- 
    Explanation of First Hint Rule: For this rule, if the WHERE clause contains the following condition the PK_Revisions index is used and added as a hint to the optimized query: Revisions.dID = *some\_value*
- 
    Explanation of Second Hint Rule: For this rule, if the WHERE clause contains either of the following conditions the dDocName index is used and added as a hint to the optimized query: Revisions.dDocName = *some\_value* Revisions.dDocName LIKE '*some\_value*'
- 
    Explanation of Third Hint Rule: For this rule, if the WHERE clause contains the following condition the condition does not meet the requirements and cannot be qualified: dStatus = 'DONE'However, if the WHERE clause contains the following condition the dStatus index is used and added as a hint to the optimized query.: dStatus = 'RELEASED'
The following sections describe the following columns in the Hint Rules Table:
Key
This column contains the unique name to identify the rule. A component can use the unique key to overwrite a particular rule. This key is usually identical to its index name because the index name is unique in the same database schema.
By default, Oracle uses a B+ Tree (binary tree) as the indexing structure to provide efficient access to logical records. B+ Tree indexes are most useful for queries involving a small number of result rows or when the user needs to execute queries using varying criteria (such as equality and range conditions). Because B+ Tree indexes store the indexed data values, these indexes are useful as sources of data if the requested value is the stored value.
However, bitmapped indexes offer substantial performance improvements with minimal storage cost compared to the default B+ Tree indexes. Bitmapped indexes are particularly effective for searching columns with poor selectivity due to having very few distinct values. Also, a bitmap is built for each value including the NULL value (which means the NULL is indexed). Overall, using bitmapped indexes is very efficient because the index lookup process is a bit-level operation and allows access to multiple indexes.
Note:
Because hint rules can be overwritten, Oracle Query Optimizer does not allow you to add a hint rule using an existing key. Therefore, it is important when you are creating your bitmapped indexes for columns that you assign unique keys.
Oracle recommends that you use bitmapped indexes for the table columns listed below, and set the index name to the corresponding column name.
- 
    Revisions table: - 
        dIndexerState 
- 
        dReleaseState 
- 
        dProcessingState 
- 
        dIsCheckedOut 
- 
        dSecurityGroup 
- 
        dStatus 
 
- 
        
- 
    WorkflowDocuments table: - dWfDocState
 
Table
This column identifies the specific database table.
Column
This column identifies the specific column within the database table listed in the Table column.
Operators
This column is a comma-delimited list of allowable operators. For more information about the valid operator options, see the Operators field and menu on the Hint Rules Configuration page. The hint rule’s operator is important in the decision of whether a hint rule will be applied to a condition.
For example, if the WHERE clause contains the following condition using the PK_Revisions index would be a very valuable hint to include in an optimized query:
Revisions.dID = 3
However, if the WHERE clause contains the following condition then using the PK_Revisions index would not be useful:
Revisions.dID > 3
Index
This column identifies the specific index to use in the optimized query if the condition meets the hint rule requirements.
Order
This column contains the preferred order to use when the rule is included in the Hint Rules Table. The highest ordered rules in a query are given precedence when deciding which hint to use.
The order values include:
- 
    5: This value indicates that the specified index is unique or does not match more than 50 rows for any value. For example, specifying dID with the Revisions, Documents, or DocMeta tables. 
- 
    4: This value indicates that the specified index should be somewhat less selective. The specifiedvalue should typically match a few rows and, at the very most, several hundred rows. For example, specifying dDocTitle with the Revisions table. 
- 
    3: This value indicates that the specified index matches less than a thousand rows. For example, specifying dInDate or dOutDate. 
- 
    2: This value indicates that the specified index matches less than ten thousand rows. 
- 
    1: This value indicates that the specified index matches more than ten thousand rows. 
Values
This column is Idoc scriptable. This column can only be defined when the Operators column value is one of the following:
- 
    inornotIn: When you use either of these operators, the value should be a comma-delimited list enclosed in parenthesis. 
- 
    range: When you use this operator, the value must use one of the following formats: - 
        Format 1: ([*<lowValue\>*],range[,<*highDateValue\>*])Examples of acceptable values include: ('Y', 'O') (,7d) ({ts '2004-12-11 12:03:23.000'}, 2d, <$dateCurrent()$>)
- 
        Format 2: #[d|h]For example, a range of five days is 5dand seven hours is7h.Note: The operators in or notIn can substitute for the operators equal and notEqual, respectively, along with their matching values. For more information about operator options, see the Operators field and menu on the Edit Hints Rule form. 
 
- 
        
The following use cases demonstrate how this column provides additional flexibility to the hint rules:
- 
    Use Case 1: State or Status Table Columns Table columns that indicate a state or status such as dReleaseState or dStatus are biased regarding the finished states. For example, dReleaseState is predisposed for ‘Y’ (released) or ‘O’ (old version). Likewise, dStatus is predisposed for RELEASED. Therefore, in WHERE clauses, conditions such as dReleaseState = YordStatus = RELEASEDmatch the majority of rows in the Revisions table. Thus, indexes for these two columns are almost useless. Conversely, the conditiondReleaseState = N(new, not yet indexed) matches only a few rows. Consequently, indexes on this column would be very helpful.
- 
    Use Case 2: Date or Number Table Columns Table columns that indicate a date or number exhibit similar behavior to state or status. For example, the condition dInDate < <$dateCurrent()$>matches most of the table rows and makes indexes on this field irrelevant. However, the combined conditionsdInDate < <$dateCurrent()$> AND dInDate > <$dateCurrent(-1)$>usually match only a small set of rows and would benefit from using the corresponding index as a hint.
AllowMultiple
This column indicates whether the defined index is used with other indexes. In Oracle, only the bitmap index can be combined.
Disabled
This column indicates whether a hint rule has been disabled. Any rule in the table can be enabled/disabled. If you disable a hint rule, a value of ‘Y’ is displayed. Existing rules can be disabled to match the current Content Server state.
For example, if a Content Server instance contains only a few distinct content revClasses, each revClass may have thousands of revisions. Therefore, the dRevClass_2 index is not very effective. In this case, this corresponding hint rule should be disabled and you should add one or more new rules with different preference orders.
Note:
Although any rule in the table can be enabled or disabled, only the rules that are added using the Edit Hints Rule form can be removed. The default hint rules that are included with the Oracle Query Optimization feature can only be disabled; they cannot be removed.
Edit Hint Rules Form
The Edit Hint Rules Form provides a way to add, remove, enable, or disable rules using the Hint Rules Configuration page. You can add a new rule to reflect new tables and indexes. Existing rules can be removed or disabled to match the current state of the Content Server instance. If you select a hint rule from the hint rule table, the Edit Hint Rules Form fields are automatically populated with the applicable values.
The Edit Hint Rules Form is displayed next to the hint rules configuration table on the Hint Rules Configuration page.
The hint rules configuration table is scheduled to reload every night and whenever a new rule is added or an existing rule is modified. The hint value is recalculated at each reload.
Although any rule in the table can be enabled or disabled, only the rules that are added through the Edit Hint Rules Form can be removed. The default hint rules that are included with the OracleQueryOptimizer component can only be disabled; they cannot be removed.
The Hint Cache
Oracle Query Optimizer also contains a hint cache to store dynamically generated hints. For example, a hint derived from a parsed query or data source is cached to maintain persistence. In this way, the hint cache provides stability for queries and data sources.
The hint cache is used during the optimization process to select hints for queries that do not contain Oracle or Content Server hints. The hint cache provides a mechanism to fine tune query hints. In addition, administrator can check/edit cache and change hint for queries at run time.
The hint cache is stored to disk every two hours and is reloaded when the Content Server instance is started.
The characteristics of the hint cache include:
Reusing Hint Cache Entries
The same query matches the same cache entry regardless of its values unless the new value does not satisfy the hint rule conditions. Two examples are included below to demonstrate how the same hint cache entry can and cannot be used for multiple queries.
Example 1: Using Similar Hint Cache Entries
In the following two queries, the same hint cache entry is used because both queries match the hint rule requirements.
- 
    QueryA: SELECT * FROM Revisions WHERE dDocName = '*name1*'
- 
    QueryB: SELECT * FROM Revisions WHERE dDocName = '*name2*'
Example 2: Using Different Hint Cache Entries
In the following two queries, the same hint cache entry cannot be used because QueryB violates the requirements for the dReleaseState hint rule. The dReleaseState hint rule requires that the dReleaseState values are neither Y (released) nor O (old revision).
- 
    QueryA: SELECT * FROM Revisions WHERE dReleaseState = 'U' AND dStatus = 'DONE'
- 
    QueryB: SELECT * FROM Revisions WHERE dReleaseState = 'Y' AND dStatus = 'DONE'
Hint Cache Management
In the hint cache, you can add a new entry, edit an existing entry, or remove an existing entry using the Hint Cache Updater page. When adding or editing hint cache entries, you must use the Content Server Hint Syntax. The ability to manage the hint cache is very useful for fine tuning query hints. The example below demonstrates the benefits of fine tuning a hint cache entry.
Example: Batchloading Unindexed Content
If you have just batchloaded 100K content items in to the Content Server and they are not yet indexed, the index-based query used above (Example 2: Using Different Hint Cache Entries) would match all of the batchloaded documents.
- 
    QueryA: If most of the batchloaded documents have not been indexed, the dReleaseState index that is used in this query is not the best choice. For the best results in this case, you should fine tune the hint cache entry to use both the dReleaseState and the dStatus indexes. Use the Hint Cache Updater page to update hint cache entries. SELECT dID FROM Revisions WHERE Revisions.dReleaseState = N'N' AND Revisions.dStatus in (N'DONE', N'RELEASED', N'DELETED') AND Revisions.dInDate<={ts '2005-02-23 17:46:38.321'}
- 
    QueryB: After updating the hint cache entry, the new optimized query is: SELECT/*+ LEADING(revisions) INDEX (revisions dReleaseState dStatus)*/ dID FROM Revisions WHERE Revisions.dReleaseState = N'N' AND Revisions.dStatus in (N'DONE', N'RELEASED', N'DELETED') AND Revisions.dInDate<={ts '2005-02-23 17:46:38.321'}
Default Capacity Algorithm
By default, the hint cache has a maximum capacity of 1000 hints. The hint cache uses the midpoint insertion least-recently-used (LRU) algorithm which is similar to the one used by Oracle and MySQL. A new entry is inserted in to the middle of the queue and each subsequent execution moves the entry up one spot.
When the number of hints in the cache exceed the maximum capacity, the entry at the bottom of the queue is removed from the cache. Thus, the LRU algorithm ensures that the most recently executed query hints are in the upper levels of the queue.
Origin of Hint Cache Keys
The hint cache key is generated from the normalized query; for more information, see Stage 3: Normalization. The cache key consists of the qualified columns (columns that are qualified by table/alias names) and columns that have a hint rule defined. The cache key excludes conditions that contain joins or subqueries.
The following example illustrates how the cache key is generated from a given query:
SELECT DocMeta.*, Documents.*, Revisions.* 
FROM DocMeta, Documents, Revisions 
WHERE DocMeta.dID = Revisions.dID AND Revisions.dID=Documents.dID AND Revisions.dDocName='abc' AND Revisions.dStatus<>'DELETED' AND (Revisions.dReleaseState='U' OR Revisions.dReleaseState='I' OR Revisions.dReleaseState='Y') AND Documents.dIsPrimary<>0
The generated cache key is as follows:
documents.disprimary:notequal:documents|revisions.ddocname:equal:revisions|revisions.dreleasestate:in:revisions|revisions.dstatus:notequal:revisions 
Hint Cache Persistence
The hint cache is designed to be persistent. To ensure the persistence, the hint cache is saved to the file system every two hours. The persisted hint cache is reloaded when the Content Server instance is started.
Using Hint Rules
The following tasks are involved in using hint rules:
To access the Edit Hint Rules Form, choose Administration, then Oracle Query Optimizer, then Hint Rules Configuration. The Hint Rules Configuration page opens, which includes the Edit Hint Rules Form.
Adding and Enabling New Hint Rules
To add a new hint rule to the Hint Rules Table:
- 
    Choose Administration, then Oracle Query Optimizer, then Hint Rules Configuration. 
- 
    In the Edit Hint Rules Form, complete the fields. For more detailed explanations of each field, see Hint Rules Table. 
- 
    Click Add. The new hint rule is added to the Hint Rules Table and is effective immediately. 
Editing Existing Hint Rules
To edit an existing hint rule in the Hint Rules Table:
- 
    Choose Administration, then Oracle Query Optimizer, then Hint Rules Configuration. 
- 
    Select the desired hint rule in the Hint Rules Table on the Hint Rules Configuration page. All of the applicable fields in the Edit Hint Rules Form are populated with the hint rule’s values. 
- 
    Edit the fields as desired. For more details on each field, see Hint Rules Table. 
- 
    Change the key. 
- 
    Click Add. The Hint Rules Table is refreshed and the new hint rule is added. The modifications are effective immediately. 
- 
    Delete the old hint rule. For additional information, see Removing Hint Rules. 
Disabling Hint Rules
Although any rule in the table can be enabled/disabled, only the rules that are added through the Hint Rules Configuration page can be removed. The default hint rules that are included with the Oracle Query Optimization feature can only be disabled; they cannot be removed.
To disable a hint rule in the Hint Rules Table:
- 
    Choose Administration, then Oracle Query Optimizer, then Hint Rules Configuration. 
- 
    Select the desired hint rule in the Hint Rules Table on the Hint Rules Configuration page. All of the applicable fields in the Edit Hint Rules Form are populated with the hint rule’s values. 
- 
    Click Disable. The Hint Rules Table is refreshed and ‘ Y’ is displayed in the Disabled column, indicating that the hint rule is deactivated.
Enabling Hint Rules
Although any rule in the table can be enabled/disabled, only the rules that are added through the Hint Rules Configuration page can be removed. The default hint rules that are included with the Oracle Query Optimization feature can only be disabled; they cannot be removed.
To enable a disabled hint rule in the Hint Rules Table:
- 
    Choose Administration, then Oracle Query Optimizer, then Hint Rules Configuration. 
- 
    Select the desired hint rule in the Hint Rules Table on the Hint Rules Configuration page. All of the applicable fields in the Edit Hint Rules Form are populated with the hint rule’s values. 
- 
    Click Enable. The Hint Rules Table is refreshed and the Disabled column is clear, indicating that the hint rule is reactivated. 
Removing Hint Rules
Although any rule in the table can be enabled or disabled, only the rules that are added through the Hint Rules Configuration page can be removed. The default hint rules that are included with the Oracle Query Optimization feature can only be disabled; they cannot be removed.
To delete a hint rule from the Hint Rules Table:
- 
    Choose Administration, then Oracle Query Optimizer, then Hint Rules Configuration. 
- 
    Select the desired hint rule in the Hint Rules Table on the Hint Rules Configuration page. All of the applicable fields in the Edit Hint Rules Form are populated with the hint rule’s values. 
- 
    Ensure that the hint rule is enabled. If the hint rule is disabled it cannot be removed. To reactivate a disabled hint rule, see Hint Rules Table. 
- 
    Click Remove. The Hint Rules Table is refreshed and the selected hint rule is removed. 
Using the Query Converter
The Query Converter can be used to view the result of a converted query and to modify a converted query by adding, editing, or deleting conditions from the WHERE clause. Modifying a converted query enables you to see exactly what will be executed when the query is submitted. Converted queries optionally can include data sources.
The following tasks are involved when you use the Query Converter:
Accessing the Query Converter Page
To access the Query Converter page:
- 
    Choose Administration, then Oracle Query Optimizer. 
- 
    Click Query Converter. 
Converting a Data Source
To convert a data source query:
- 
    If applicable, on the Query Converter page select Use Data Source. The data source-related fields are displayed on the Query Converter page. 
- 
    Select the desired data source from the DS Name menu. The data source query is displayed in below the DS Name field. 
- 
    Enter the applicable information for additional parameters and WHERE clauses. 
- 
    Click Convert Query. The data source is converted and the results are displayed in a text area above the Use Data Source check box. To view an example of a converted data source query, see Figure 5. 
Converting a Query
To convert a query:
- 
    If applicable, on the Query Converter page deselect Use Data Source. The data source-related fields are hidden from the Query Converter page. 
- 
    Enter the applicable information for the query. 
- 
    Click Convert Query. The query is converted and the results are displayed in a text area above the Use Data Source check box. To view an example of a converted query, see Figure 6. 


Editing a Converted Data Source or Query
After the data source or query is converted, the results are displayed above the Use Data Source check box. Because the conversion process clears the fields, the converted query can only be modified by entering new information in the fields. To edit information for a data source or query, see the applicable sections in Converting a Data Source.
Updating the Hint Cache
The following tasks are involved when updating the hint cache:
Accessing the Hint Cache Updater Page
To access the Hint Cache Updater page:
- 
    Choose Administration, then Oracle Query Optimizer. 
- 
    Click Hint Cache Updater. 
Checking the Hint Cache from a Data Source
To check the hint cache using a data source:
- 
    On the Hint Cache Update page, select Use Data Source. The data source-related fields are displayed on the Hint Cache Updater page. 
- 
    Select the desired data source from the DS Name menu. The data source query is displayed in below the DS Name field. 
- 
    Enter the applicable information for the additional parameters, WHERE clause, and hints. 
- 
    Click Check Cache. The results are displayed above the Use Data Source check box. To view an example of an unsuccessful hint search, see Figure 7. 

Checking from a Query
To check the hint cache using a query:
- 
    On the Hint Cache Update page, ensure the Use Data Source check box is unselected. The data source-related fields are hidden from the Query Converter page. 
- 
    Enter the applicable information. 
- 
    Click Check Cache. The results are displayed above the Use Data Source check box.To view an example of an unsuccessful hint search, see Figure 8. To view an example of a successful hint search, see Figure 9. 


Modifying an Existing Hint Cache Query Using Data Source
To modify a hint cache query using a data source:
- 
    On the Hint Cache Updater page, select Use Data Source. The data source-related fields are displayed on the Hint Cache Updater page. 
- 
    Select the desired data source from the DS Name menu. The data source query is displayed below the DS Name field. 
- 
    Enter the applicable information for the additional parameters, WHERE clause, and hints. 
- 
    Click Update Cache to overwrite the previous hint cache. The results are displayed in a text box above the Use Data Source check box. To see an example of successfully adding a new hint to a query and updating the hint cache, see the page capture included in this section. 
Modifying an Existing Hint Cache Using a Query
To modify a hint cache using a query:
- 
    On the Hint Cache page, ensure that the Use Data Source check box is unselected. The data source-related fields are hidden from the Query Converter page. 
- 
    Enter the applicable information. 
- 
    Click Update Cache to overwrite the previous hint cache. The results are displayed above the Use Data Source check box. On the page capture note that the new hint was added and the hint cache was updated. 

Removing a Hint Cache Data Source Entry
To remove a hint cache data source entry:
- 
    On the Hint Cache Updater page, select Use Data Source. The data source-related fields are displayed on the Hint Cache Updater page. 
- 
    Select the desired data source from the DS Name menu. The data source query is displayed below the DS Name field. 
- 
    Enter the applicable information for the additional parameters, WHERE clause, and hints. 
- 
    Click Remove. The information entered in to the fields is removed. To see an example of successfully removing a hint from a query and the hint cache, see the page capture included in this section. 
Removing a Hint Cache Query
To remove a hint cache query:
- 
    On the Hint Cache Updater page, ensure that the Use Data Source check box is unselected. The data source-related fields are hidden from the Query Converter page. 
- 
    Enter the applicable information for the query and hints. 
- 
    Click Remove. The results are displayed above the Use Data Source check box. On the page capture note that the previously added hint was deleted from the query and hint cache. 

Improving Search Performance
This section contains information about improving search performance.
Improving Database Search on the Title Field
if you frequently search on the Title field and your site has more than 1 million records, and you are using database search, it is recommended that you create an index based on dDocTitle and dReleaseState.
Reducing Unnecessary SQL Queries
If you find that you have unnecessary SQL queries being triggered because each query is determining the folder path for every entry part of the search result set, and you do not need the folder path information, you can improve performance by turning off the FolderPathInSearchResults configuration variable in the Additional Configuration Variables portion of the config.cfg file.