Dies ist leider nicht möglich, da der Cursorname beim Open/Fetch/Close statisch im Programm angegeben werden muss.

Aber wozu auch ?
Nach einem Close C1 lässt sich mittels Prepare C1 from der Cursor ja neu definieren, so dass der nächste Open den neuen Select ausführt.
Einen dynamischen Cursor benötigt man absolut nicht.

Verwendet man sogar beim Fetch eine SQLDA läßt sich sogar der Select absolut dynamisch verarbeiten.
Mittels Describe Statement lassen sich auch dei Felddefinitionen in eine SQLDA auslesen, so dass man nur noch per %alloc() Speicher für die Inhalte zuweisen muss.

Ansonsten ist nur das etwas mühsame CLI-Interface (C-SQL-Routinen) verwenden.