Adobe ColdFusion 8

cfprocresult

Description

Associates a query object with a result set returned by a stored procedure. Other ColdFusion tags, such as cfoutput and cftable, use this query object to access the result set. This tag is nested within a cfstoredproc tag.

Category

Database manipulation tags

Syntax

<cfprocresult 
    name = "query name"
    maxRows = "number"
    resultSet = "1-n">

Note: You can specify this tag's attributes in an attributeCollection attribute whose value is a structure. Specify the structure name in the attributeCollection attribute and use the tag's attribute names as structure keys.

See also

cfinsert, cfprocparam, cfquery, cfqueryparam, cfstoredproc, cftransaction, cfupdate; "Optimizing database use" 37 in "Designing and Optimizing a ColdFusion Application" 13 in the ColdFusion Developer's Guide

Attributes

Attribute

Req/Opt

Default

Description

name

Required

 

Name for the query result set.

maxRows

Optional

-1 (All)

Maximum number of rows returned in result set.

resultSet

Optional

1

Names one result set, if stored procedure returns more than one.

Usage

To enable access to data returned by the stored procedure, specify one or more cfprocresult tags. If the stored procedure returns more than one result set, use the resultSet attribute to specify which of the stored procedure's result sets to return.

The resultSet attribute must be unique within the scope of the cfstoredproc tag. If you specify a result set twice, the second occurrence overwrites the first.

CFML supports Oracle 8 and 9 Reference Cursor type, which passes a parameter by reference. Parameters that are passed this way can be allocated and deallocated from memory within the execution of one application. To use reference cursors in packages or stored procedures, use the cfprocresult tag. This causes the ColdFusion JDBC database driver to put Oracle reference cursors into a result set. (You cannot use this method with Oracle's ThinClient JDBC drivers.)

Example

<!--- This example executes a Sybase stored procedure that returns three result sets, two
    of which we want. The stored procedure returns status code and one output parameter, which
    we display. We use named notation for parameters. --->
<!--- cfstoredproc tag --->
<cfstoredproc procedure = "foo_proc"
    dataSource = "MY_SYBASE_TEST" username = "sa"
    password = "" dbServer = "scup" dbName = "pubs2"
    returnCode = "Yes" debug = "Yes">
    <!--- cfprocresult tags --->
    <cfprocresult name = RS1>
    <cfprocresult name = RS3 resultSet = 3>
    <!--- cfprocparam tags --->
    <cfprocparam type = "IN" CFSQLType = CF_SQL_INTEGER value = "1">
    <cfprocparam type = "OUT" CFSQLType = CF_SQL_DATE variable = FOO>
    <!--- Close the cfstoredproc tag. --->
</cfstoredproc>
<cfoutput>
    The output param value: '#foo#'<br>
</cfoutput>
<h3>The Results Information</h3>
<cfoutput query = RS1>#name#,#DATE_COL#<br>
</cfoutput>
<p></p>
<cfoutput>
    <hr>
    <p>Record Count: #RS1.recordCount# <p>Columns: #RS1.columnList#</p>
    <hr>
</cfoutput> 
<cfoutput query = RS3>#col1#,#col2#,#col3#<br>
</cfoutput>
<p></p>
<cfoutput>
    <hr>
    <p>Record Count: #RS3.recordCount# <p>Columns: #RS3.columnList#</p>
    <hr>
    The return code for the stored procedure is:
    '#cfstoredproc.statusCode#'<br>
</cfoutput>
...