Previous Topic

Next Topic

Book Contents

Book Index

User-defined Parameters

You can define a number of User-Defined Parameters that can be used throughout AQT.

Comparison to Substitutional Parameters

User-Defined Parameters are not to be confused with substitutional parameters described in Adding parameters to a query. The use of ? in an SQL statement to indicate a substitutional parameter is a standard part of the SQL interface to your database. The query (complete with ?s) is passed to your database for processing. The database responds to AQT with the numbers (and types) of the parameter values that need to be supplied. AQT will prompt you for these.

The use of substitutional parameters has a number of advantages:

There are some disadvantages of substitutional parameters:

Use of User-Defined Parameters

User-defined parameters provide an alternate mechanism for using parameters in your SQL.

Parameters are indicated with a $ followed by the parameter name. Example:

select * from customers where cust_code = '$custcode'

Note that, unlike substitutional parameters, you need to enclose string values in quotes.

Enabling the use of User-Defined Parameters

For batch-mode AQT, User-defined Parameters are always enabled.

For online AQT, User-defined Parameters are (by default) not enabled. You can enable this by (from the Run SQL window), going Tools > Parameters, then checking Enable Parameters. Click on OK. This setting is saved between sessions, so you only have to do this once.

Parameter Character

On the User-defined Parameters window, you can also specify whether parameters are to be indicated with a $ or a colon. This is done with the Indicate parameters with option. By default, this will be a $. The only choices are $ or colon.

Defining User-Defined Parameters

Parameters can be defined in three ways:

Parameter values are saved to disk between AQT sessions. The file they are saved in is parms.txt in your Default Directory. The parms are saved whenever AQT shuts down successfully, or when OK is clicked on the User-Defined Parameters window.

Parameters are often used when running batch scripts. Any changes to parameters done during batch scripts are not saved.

Referencing Another User-Defined Parameter

A parameter can reference parameter.

Example:

Parameter

Value

date07

2007-03-31

date08

2008-03-31

rundate

$date07

In this, the value of rundate is the name of another parameter.

When you specify:

select * from accounts where transaction_date > '$rundate'

the following will be run:

select * from accounts where transaction_date > '2007-03-31'

Using the function Tools > Show SQL after parameter replacement is useful for seeing how parameters will be resolved.