23 Pipelined and Parallel Table Functions
These routines must be implemented to define pipelined and parallel table functions in C.
See Also:
Using Pipelined and Parallel Table Functions for an overall explanation of pipelined and parallel table functions
23.1 Routines for Pipelined and Parallel Table Functions in C
The following C methods, summarized in support parallel and pipelined table functions.
Table 23-1 Summary of Pipelined and Parallel Table Functions for C
| Function | Description | 
|---|---|
| Performs cleanup operations after scanning a table function. | |
| Returns describe information for a table function whose return type is  | |
| returns the next batch of rows from a table function. | |
| Prepares the scan context and other query information at compile time. | |
| initializes the scan of a table function. | 
23.1.1 ODCITableClose()
ODCITableClose performs cleanup operations after scanning a table function.
                        
Syntax
MEMBER FUNCTION ODCITableClose( self IN <imptype>) RETURN NUMBER;
| Parameter | In/Out | Description | 
|---|---|---|
| self | IN | The scan context set up by previous scan routine invocation | 
Returns
ODCIConst.Success on success, ODCIConst.Error otherwise.
                        
Usage Notes
- 
                              Oracle invokes ODCITableCloseafter the last fetch call. The scan context is passed in as a parameter.ODCITableClosethen performs any necessary cleanup operations, such as freeing memory.
- 
                              If ODCITablePrepare is implemented, this routine is only called one time, at the end of query execution, rather than each time the table function exits. 
23.1.2 ODCITableDescribe()
ODCITableDescribe returns describe information for a table function whose return type is ANYDATASET.
                        
Syntax
STATIC FUNCTION ODCITableDescribe( rtype OUT ANYTYPE, <args>) RETURN NUMBER;
| Parameter | In/Out | Description | 
|---|---|---|
| rtype | OUT | The  | 
| args | IN | The set of zero or more user specified arguments for the table function. | 
Returns
ODCIConst.Success on success, ODCIConst.Error otherwise.
                        
Usage Notes
- 
                              If the optional routine ODCITableDescribeis implemented, Oracle invokes it at query compilation time to retrieve the specific type information.
- 
                              This interface is applicable only for table functions whose return type is ANYDATASET. The format of elements within the returned collection is conveyed to Oracle by returning an instance ofANYTYPE. TheANYTYPEinstance specifies the actual structure of the returned rows of the specific query.
- 
                              ANYTYPEprovides a data type to model the metadata of a row: the names and data types of all the columns (fields) comprising the row. It also provides a set of PL/SQL and C interfaces for users to construct and access the metadata information.ANYDATASET, likeANYTYPE, contains a description of a given type, butANYDATASETalso contains a set of data instances of that type
- 
                              The following example shows a query on a table function that uses the ANYDATASETtype:SELECT * FROM TABLE(CAST(AnyBooks('http://.../books.xml') AS ANYDATASET));At query compilation time, Oracle invokes the ODCITableDescriberoutine. The routine typically uses the user arguments to figure out the nature of the return rows. In this example,ODCITableDescribeconsults the DTD of the XML documents at the specified location to determine the appropriateANYTYPEvalue to return. EachANYTYPEinstance is constructed by invoking the constructor APIs with this field name and data type information.
- 
                              Any arguments of the table function that are not constants are passed to ODCITableDescribeasNULLs because their values are not known at compile time.
See Also:
Transient and Generic Types for a discussion of ANYTYPE, ANYDATA, and ANYDATASET
23.1.3 ODCITableFetch()
ODCITableFetch returns the next batch of rows from a table function.
                        
Syntax
MEMBER FUNCTION ODCITableFetch( self IN OUT <imptype>, nrows IN NUMBER, rws OUT <coll-type>) RETURN NUMBER;
| Parameter | In/Out | Description | 
|---|---|---|
| self | IN OUT | The in-bound is the scan context set up by previous scan routine invocation; the outbound is the scan context to be passed to later scan routine invocations. | 
| nrows | IN | The number of rows the system expects in the current fetch cycle. The method can ignore this value and return a different number of rows. If fewer rows are returned, the method is called again; if more rows are returned, they are processed in the next cycle. | 
| rws | OUT | The next batch of rows from the table function. This is returned as an instance of the same collection type as the return type of the table function. | 
Returns
ODCIConst.Success on success, ODCIConst.Error otherwise.
                        
Usage Notes
- 
                              ODCITableFetchis invoked one or more times by Oracle to retrieve all the rows in the collection returned by the table function. The scan context is passed in as a parameter. TypicallyODCITableFetchuses the input scan context and computes the next set of rows to be returned to Oracle. In addition, it may update the scan context accordingly.
- 
                              Returning more rows in each invocation of fetch()reduces the number of fetch calls that must be made and thus improves performance.
- 
                              Oracle calls ODCITableFetchrepeatedly until all rows in the table function's collection have been returned. When all rows have been returned,ODCITableFetchshould return a null collection.
23.1.4 ODCITablePrepare()
Prepares the scan context and other query information at compile time.
Syntax
STATIC FUNCTION ODCITablePrepare( sctx OUT <imptype>, tf_info SYS.ODCITabFuncInfo, args);
| Parameter | In/Out | Description | 
|---|---|---|
| sctx | OUT | The scan context returned by this routine. This value is passed in as a parameter to the later scan routines. The scan context is an instance of the object type containing the implementation of the  | 
| tf_info | 
 | Contains the projection information and the return type's table descriptor object (TDO): 
 | 
| args | IN | The arguments that are passed to the table function. This method is invoked at compile time; thus, only literal arguments have values. Column and expression arguments are passed as null values. | 
Usage Notes
- 
                              This method prepares the scan context based on the information known at compile time. This scan context is passed to ODCITableStartwhen it is called at the beginning of query execution.
- 
                              If this optional method is implemented, ODCITableCloseis only called one time, at the end of query execution. Each time the table function is restarted,ODCITableStartis called and passed the scan context. This allows the table function to maintain context between restarts, and to perform cleanup operations only one time at the end of query execution.
23.1.5 ODCITableStart()
ODCITableStart initializes the scan of a table function.
                        
Syntax
STATIC FUNCTION ODCITableStart( sctx IN OUT <imptype>, <args>) RETURN NUMBER;
| Parameter | In/Out | Description | 
|---|---|---|
| self | IN OUT | The scan context returned by this routine. This value is passed in as a parameter to the later scan routines. The scan context is an instance of the object type containing the implementation of the  | 
| args | IN | Set of zero or more arguments specified by the user for the table function | 
| rws | OUT | The next batch of rows from the table function. This is returned as an instance of the same collection type as the return type of the table function. | 
Returns
ODCIConst.Success on success, ODCIConst.Error otherwise.
                        
Usage Notes
- 
                              If ODCITablePrepareis not implemented, this is the first routine that is invoked to begin retrieving rows from a table function. This routine typically performs the setup needed for the scan. The scan context is created (as an object instancesctx) and returned to Oracle. The arguments to the table function, specified by the user in theSELECTstatement, are passed in as parameters to this routine. IfODCITablePrepareis implemented, it creates the scan context at compile time, and that scan context is passed in to this routine.
- 
                              Any REF CURSORarguments of the table function must be declared asSYS_REFCURSORtype in the declaration of theODCITableStartmethod.