Hi,

you have to distinguish between hard cursor closes and soft closes or
implicitely and explicitely closes.
An implicitely close is performed as soon the SQL-Statement CLOSE will be
performed. An other reason for an implictely close is executing one of the
SQL-Statements COMMIT or ROLLBACK, if WITH HOLD is not specified in the
DECLARE statement.
With an implictely close an ODP can be reused, if it is reuseable. (CLOSE
and OPEN of serial cursor, will cause the cursor to be possitioned at the
beginning of the result set.)

An explicitely close is performed depending on the OPTION CLOSQLCSR in the
compile command or specified in an SET OPTION statement at either the end of
the activation group or at the end of the module. If you want to close a
cursor explicitely at the end of a program, use eithe activation group *NEW
or a named activation group combined with the execution of the CL-Command
RCLACTGRP at the end of the programm.
With an explictely close, all ODPs get deleted. If you execute the same SQL
statement again the complete OPEN and optiomization process must be executed
again.

May be I should explain what happens at an OPEN process:
1. First time an SQL statement gets executed:
   - If the SQL statement is executed by the new SQL query enginge (SQE)
access plans in the SQE plan cache get checked and validated.
   - If no access plan is available in the plan chache or the SQL statement
is executed by the old Classic Query Engine, access plans stored in the
(service-)programm objects (for static SQL) or in an SQL package for
(extended dynamic SQL) get validated.
   - If no access plan is available or dynamic SQL is used, an access plan
gets created from scratch.
     An access plan contains the information about the access methods used,
such as table scan or index access only or if temporary indexes or tables
must be generated.
     (Access plans for static SQL get stored in the (service-)program
objects, for extended SQL access plans get stored in the appropriate SQL
package. Access plans for dynamic SQL get NOT stored! If SQE is used to
execute the SQL statement, the access plan for all kinds of SQL-statements
additionally get stored in the SQE plan chache.)
   - When building or validating an access plan all indexes get checked to
determine the optimal one.

   - After creation or validation of the access plans, the data path gets
implemented.
     That means temporary tables or indexes are created, dynamic bitmaps get
generated and a lot more what is neccessary to get access to the data.
     Note: An access plan is the receipe, but it does no cooking.

   - After the implementation of the data path, the SQL statement can be
executed.

   - The first time the SQL-Statement gets executed the access path gets
deleted after execution.

2. Second time an SQL statement gets executed:
   - Access plans are checked and eventually updated again.
   - The data path must be built again.
   - The SQL statement gets executed.
   - If the data path is reusable, it won't get deleted anymore and can be
reused. (ODP=Open data path)

3. Beginning with the third execution, the ODP gets reused, and no
OPEN-process (access plan validation ...) gets executed.

Changing the library list or overriding/remove overrides affected
files/tables will cause an hard close of the cursors, i.e. delete open data
paths.

If you hard close your cursor at the end of a program/module, each time the
SQL statement gets executed again, the open process/optimization will be
executed again.

For performance issues, you should avoid hard closing your cursors whenever
possible. As far as I know up to 512 ODP can be hold in one job (by
default). If more data paths are needed the oldest ones get removed.

Each SQL statement gets its own ODP, that means executing the same SQL
statement in two different programs or subroutines in the same job, will
cause an optimization process and building an ODP for each statement.
Access plans can be shared, but not ODPs.

Mit freundlichen Gru?en / Best regards

Birgitta

"Shoot for the moon, even if you miss, you'll land among the stars."
(Les Brown)

-----Ursprungliche Nachricht-----
Von: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx]Im Auftrag von Jeff Young
Gesendet: Montag, 22. Mai 2006 21:54
An: rpg400-l@xxxxxxxxxxxx
Betreff: SQL Close Cursor Action


When creating an SQLRPGLE module, the only actions I can specify for closing
a cursor are *ENDMOD or *ENDACTGRP.
  What I would like to do is have all cursors closed when the program that
the module is a member of ends.
  Is there any way I can do this short of calling the module at program end
with a code to have it manualy close the cursor?

  TIA,



Jeff Young
Sr. Programmer Analyst
Dynax Solutions, Inc.
A wholly owned subsidiary of enherent Corp.
IBM -e(logo) server Certified Systems Exper - iSeries Technical Solutions
V5R2
IBM  Certified Specialist- e(logo) server i5Series Technical Solutions
Designer V5R3
IBM  Certified Specialist- e(logo)server i5Series Technical Solutions
Implementer V5R3












---------------------------------
Feel free to call! Free PC-to-PC calls. Low rates on PC-to-Phone.  Get
Yahoo! Messenger with Voice
--
This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/rpg400-l.




As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.