%iKnow.Queries.Utils
Class %iKnow.Queries.Utils Extends %RegisteredObject [ Deprecated, System = 4 ]
Utility class grouping some utility and informative methods complementing the iKnow Query APIs.
Methods
GetQueryResultColumns
ClassMethod GetQueryResultColumns(queryClass As %String, queryName As %String, Output columns) As %Status
Returns a list of the columns returned by the query identified by the queryClass and queryName parameters in the following format: columns(index) = $lb(name,type). If the supplied parameters do not correspond to a known query, an error is returned.
GetParameterDisplayName
ClassMethod GetParameterDisplayName(paramName As %String) As %String
Returns a displayable name for most query parameter names in use. If no more readable form is available (for example if it's too trivial), paramName itself is returned.
GetParameterValues
ClassMethod GetParameterValues(paramName As %String, Output values, queryClass As %String = "", queryName As %String = "") As %Boolean
Returns a list of the possible parameter values for a number of common query parameters in a variable containing key-displayValue pairs: values(i) = $lb(key, value). The %Boolean returned expresses whether this is a known parameter for which a meaningful list of values can be returned.
The optional queryClass and queryName parameters will in some cases limit the possible values to the allowed ones supported by that particular query.
Note: for the "pageSize" parameter, this method will return a limited number of possible values to make this method more useful for internal purposes, but obviously any positive numeric value will do.
DumpQueryResult
ClassMethod DumpQueryResult(pFilename As %String, pQueryClass As %String, pQueryName As %String, pQueryParams...) As %Status
This utility method executes a query of one of the primary iKnow query APIs (with the *API suffix), as identified by pQueryClass and pQueryName, and writes the output as a CSV file to pFilename. This will overwrite the output file if it already exists and the output will include a header line containing column names and types.
pQueryParams... is to contain all the parameters you would normally supply to the query, except for its ByRef result parameter, which is taken care of by this utility.
For example, a query defined as
User.MyAPI.GetXByY(ByRef result, domainId As %Integer, x As %String, y As %String)
will be called as follows:
do ##class(%iKnow.Queries.Utils).DumpQueryResult("C:\temp\myFile.csv", "User.MyAPI", "GetXByY", domainId, x, y)