/
Addressing Columns Using Their Number

Addressing Columns Using Their Number

You can access columns using their numbers with $ followed by the column number.

This example

SELECT [f], [c]
FROM [dms]:[sysFolder] [f] JOIN [dms]:[sysParent2Child] JOIN [dms]:[customer] [r]

can therefore be reformulated to

SELECT $1, $3
FROM [dms]:[sysFolder] [f] JOIN [dms]:[sysParent2Child] JOIN [dms]:[customer] [r]
If there is a more complex type in the specified target column, then you can access its elements directly.
SELECT $1.[sysId]
FROM [dms]:[customer]

In the same way, you can also access the WHERE clause from the FROM clause.

SELECT $3
FROM [dms]:[sysFolder] [f] JOIN [dms]:[sysParent2Child] JOIN [dms]:[customer] [r]
WHERE $1.[sysid] = id'ABCDEF12345678901234567890123456'
This notation can also be used in the ORDER BY clause.
…ORDER BY $ 1

This notation is particularly suitable for dynamically combined queries. Imagine a script that receives any transferred eSQL query, in which it is only stipulated that it leads to a result table with a column and that objects are selected in the first column. Now you would like to build a filter around this query, e.g., limiting the search to a particular folder.

SELECT $3
FROM [dms]:[sysFolder] [f]
 JOIN [dms]:[sysParent2Child] [r],
 (<given query>) AS [x]
WHERE $3.[sysid] = [r].[sysid2]

The script is independent of the name of the given query's column. Without the $ notation, you need to request a particular name of the column from the caller.