Usage
The base.SqlHandle
class is a built-in class providing dynamic SQL support with
a 3GL API.
Compared to regular SQL cursor instructions, the main purpose of the
base.SqlHandle
class is to provide column name and SQL data type information with
the getResultName()
and getResultType()
methods. It is also
possible to write generic code for parameterized queries with the setParameter()
method.
MAIN
DEFINE h base.SqlHandle
CONNECT TO "mydb"
LET h = base.SqlHandle.create()
CALL my_prepare(h)
CALL my_execute(h)
END MAIN
FUNCTION my_prepare(h)
DEFINE h base.SqlHandle
CALL h.prepare("INSERT INTO cust VALUES ( ...
END FUNCTION
FUNCTION my_execute(h)
DEFINE h base.SqlHandle
CALL h.execute()
END FUNCTION
Executing a simple SQL statement without a result set
Perform the following steps, to execute an SQL statement without a result set:
- Define the SQL handle variable as
base.SqlHandle
- Create an SQL handle object
base.SqlHandle.create()
prepare(sql-text)
- For each SQL parameter:
setParameter(index, value)
execute()
-- test forSQLCA.SQLCODE
- Repeat from (5), (4), or (3)
Executing a SQL statement returning a result set
Perform the following steps, to execute an SQL statement with a result set:
- Define the SQL handle variable as
base.SqlHandle
- Create an SQL handle object
base.SqlHandle.create()
prepare(sql-text)
- For each SQL parameter:
setParameter(index, value)
open()
fetch()
-- test forSQLCA.SQLCODE == 100
getResultCount()
-- for each column index:getResultName(index)
getResultType(index)
getResultValue(index)
close()
- Repeat from (6), (4), (5), or (3)
Executing a SQL statement returning a result set, as scrollable cursor
Perform the following steps, to execute an SQL statement with a result set and scroll forwards and backwards in the rows:
- Define the SQL handle variable as
base.SqlHandle
- Create an SQL handle object
base.SqlHandle.create()
prepare(sql-text)
- For each SQL parameter:
setParameter(index, value)
openScrollCursor()
fetch()
(next row),fetchLast()
,fetchFirst()
,fetchPrevious()
,fetchRelative(n)
orfetchAbsolute(n)
-- test forSQLCA.SQLCODE == 100
getResultCount()
-- for each column index:getResultName(index)
getResultType(index)
getResultValue(index)
close()
- Repeat from (6), (4), (5), or (3)
Creating rows with an insert cursor
Perform the following steps, to insert many rows with an SQL handle insert cursor:
- Define the SQL handle variable as
base.SqlHandle
- Create an SQL handle object
base.SqlHandle.create()
prepare(insert-stmt-with-params)
BEGIN WORK
open()
- For each row to insert:
- For each SQL parameter:
setParameter(index, value)
put()
- For each SQL parameter:
close()
COMMIT WORK
- Repeat from (4) or (3)
SQL error handling with SqlHandle
NOTFOUND
) can be
done with SqlHandle objects as with regular SQL instruction, by testing the
SQLCA.SQLCODE
register, and by using TRY/CATCH
blocks or WHENEVER
ERROR
.MAIN
DEFINE h base.SqlHandle
CONNECT TO "mydb"
LET h = base.SqlHandle.create()
TRY
CALL h.prepare("SELECT * FROM mytab")
CALL h.open()
CALL h.fetch()
DISPLAY h.getResultValue(1)
CALL h.close()
CATCH
DISPLAY "SQL ERROR:", SQLCA.SQLCODE
END TRY
END MAIN