Canvas now enables you to apply constructed queries for SQL data sources. The constructed queries should initiate the dynamic binding of specified parameters, along with the applied functions in a streamlined manner. While defining parameters in constructed queries, the defined parameters vary in accordance with the applied filters, as specified by the end user. To nullify the unintended variation in parameters, new functions have been introduced to initiate the dynamic binding of parameters, with precisely constructed queries. The three new functions, applyWhen, applyWhenAnd and applyWhenOr can be used effectively to apply constructed queries for SQL data sources.

...

  1. Right-click the existing Connection and select the Create Data Source option. For detailed information on creating Connections, refer Create a Database Connection.



    The Create New Data Source page appears.



  2. In the Data Source Name field, provide a unique data source name, e.g. ACCOUNT DETAILS.

    Note

    The Connection Name is a non-editable field.




  3. Enable the Is SQL? Toggle option.



  4. In the Data Query field, provide the appropriate constructed queries, as shown in the following code snippet:

    Code Block
    languagesql
    SELECT * FROM DEMO_ACCOUNT_SUMMARY_DATA where 
    	{{applyWhen({
    				"parameterId" : "ACCOUNT_TYPE", 
    				"EMPTY" : "ACCOUNT_TYPE is null", 
    				"DEFAULT" : "ACCOUNT_TYPE = #{ACCOUNT_TYPE}"
    				})
    	 }}


    Note

    In the aforementioned code snippet, the ACCOUNT_TYPE serves as the parameter in the defined Where Clause of the constructed query. To define a switch case for the constructed query string, specify the parameter value and provide the possible cases for defining the constructed queries. The applyWhen function initiates the dynamic binding of the specified parameter, e.g. ACCOUNT_TYPE, thereby ensuring that constructed queries are defined in a precise manner. Alternatively, if the parameter is not specified or defined in the constructed queries, then you can make use of the EMPTY case in the applyWhen function, whereas if the specified parameter is available in the list of cases, defined as constructed queries, then you can make use of the the specified parameter case, e.g. ACCOUNT_TYPE, in the applyWhen function. If the parameter is not available in the listed case of the constructed queries, then you can make use of the DEFAULT case to specify the default parameter value in the applyWhen function.




  5. To make use of the AND operator, specify the applyWhenAnd function as a prefix to the constructed query string, as shown in the following code snippet:

    Code Block
    languagesql
    SELECT * FROM DEMO_ACCOUNT_SUMMARY_DATA where 
    	{{applyWhenAnd({
    				"parameterId" : "ACCOUNT_TYPE", 
    				"EMPTY" : "ACCOUNT_TYPE is null", 
    				"DEFAULT" : "ACCOUNT_TYPE = #{ACCOUNT_TYPE}"
    				   })
    	 }}


    Note

    In the aforementioned code snippet, the Where Clause for the ACCOUNT_TYPE parameter is specified as null with the AND operator, e.g. AND ACCOUNT_TYPE is null.




  6. To make use of the OR operator, specify the applyWhenOR function as a prefix to the constructed query string, as shown in the following code snippet:

    Code Block
    languagesql
    SELECT * FROM DEMO_ACCOUNT_SUMMARY_DATA where 
    	{{applyWhenOr({
    				"parameterId" : "ACCOUNT_TYPE", 
    				"EMPTY" : "ACCOUNT_TYPE is null", 
    				"DEFAULT" : "ACCOUNT_TYPE = #{ACCOUNT_TYPE}"
    				  })
    	 }}


    Note

    In the aforementioned code snippet, the Where Clause for the ACCOUNT_TYPE parameter is specified as null with the OR operator, e.g. OR ACCOUNT_TYPE is null.




  7. To save the data source, click Save.



    A confirmation message, indicating a successful save, appears.



  8. Click Ok.