9.6.2.7 rqGroupEval2 Function
The function rqGroupEval2 when used in Oracle Autonomous AI Database, groups data by one or more columns and runs a user-defined R function on each group.
               
The function rqGroupEval2 runs the user-defined R function
      specified by the scr_name parameter. Pass data to the user-defined R function
      with the inp_nam parameter, pass arguments to the user-defined R function
      with the par_lst parameter. Specify one or more grouping columns with the
        grp_col parameter. Define the form of the returned value with the
        out_fmt parameter.
               
Syntax
rqGroupEval2 (
    INP_NAM VARCHAR2,
    PAR_LST VARCHAR2,
    OUT_FMT VARCHAR2,
    GRP_COL VARCHAR2,
    SCR_NAME VARCHAR2,
    SCR_OWNER VARCHAR2 DEFAULT NULL,
    ENV_NAME  VARCHAR2 DEFAULT NULL
    )Parameters
| Parameter | Description | 
|---|---|
| 
 | The name of a table or view that specifies the data to pass to the R function specified by the SCR_NAME parameter. If using a table or view owned by another user, use the format 
 You must have read access to the specified table or view. | 
| 
 | A JSON string that contains additional parameters to pass to the user-defined R
                  function specified by the  For example, to run the R function with data parallelism, use: 
 See also: Special Control Arguments | 
| 
 | The format of the output returned by the function. It can be one of the following: 
 See also: Output Formats. | 
| 
 | The names of the grouping columns by which to partition the data. Use commas to
                  separate multiple columns. For example, to group by  
 | 
| 
 | The name of a user-defined R function in the OML4R script repository. | 
| 
 | The owner of the registered R script. The default value is NULL. IfNULL, will search for the R script in
                the user’s script repository. | 
| 
 | The name of the conda environment that should be used when running the named user-defined R function. | 
Return Value
The user-defined rqGroupEval2 function returns a table that has the
        structure specified by the OUT_FMT parameter value.
                  
Examples
Example 9-45 Using an rqGroupEval2 Function
This example uses the IRIS table created in the example shown in rqTableEval2 Function (Autonomous AI Database). Define the R function and store it with the name groupCount in the script repository.
%script
BEGIN
    sys.rqScriptCreate('groupCount',
        'function(dat){
            x <- data.frame(table(dat$Species))
            names(x) <- c("Species", "Count")
            x}',
        FALSE, TRUE); -- V_GLOBAL, V_OVERWRITE
END;
/The output is similar to the following:
PL/SQL procedure successfully completed. 
---------------------------Example 9-46 JSON Output
Calls the rqGroupEval2 function, which runs the user defined function
          groupCount. In the function, the INP_NAM argument
        specifies the data in the IRIS table to pass to the function. The PAR_LST
        argument specifies the special control argument ore_input_type. In the
          OUT_FMT argument, the string 'JSON', specifies that the table returned
        contains a CLOB that is a JSON string The GRP_COL parameter specifies the
        column to group by. The SCR_NAME parameter specifies the user-defined R
        function stored with the name groupCount in the script repository.
                  
%script
set long 500
SELECT * FROM table(rqGroupEval2(
            inp_nam => 'IRIS',
            par_lst => '{"ore_service_level":"MEDIUM", "ore_parallel_flag":true}',
            out_fmt => 'JSON',
            grp_col => 'Species',
            scr_name => 'groupCount'));The output is similar to the following:
NAME VALUE 
[{"Count":50,"Species":"setosa"},{"Count":50,"Species":"versicolor"},{"Count":50,"Species":"virginica"}]Example 9-47 XML Output
Calls the rqGroupEval2 function, which runs the user defined function groupCount. In the function, the INP_NAM argument specifies the data in the IRIS table to pass to the function. The PAR_LST argument specifies using MEDIUM service level with special control argument ore_service_level and set the special control argument ore_parallel_flag to true. The OUT_FMT parameter specifies returning the value in XML format. The GRP_COL parameter specifies the column to group by. The SCR_NAME parameter specifies the user-defined R function stored with the name groupCount in the script repository.
                  
%script
set long 500
SELECT * FROM table(rqGroupEval2(
            inp_nam => 'IRIS',
            par_lst => '{"ore_service_level":"MEDIUM", "ore_parallel_flag":true}',
            out_fmt => 'XML',
            grp_col => 'Species',
            scr_name => 'groupCount'));The output is similar to the following:
NAME VALUE
       <root><frame_obj><ROW-frame_obj><Species>setosa</Species><Count>50</Count></ROW-frame_obj><ROW-frame_obj><Species>versicolor</Species><Count>50</Count></ROW-frame_obj><ROW-frame_obj><Species>virginica</Species><Count>50</Count></ROW-frame_obj></frame_obj></root>Example 9-48 Relational Output
Run the Select statement to get a Relational output.
                  
%script
SELECT * FROM table(rqGroupEval2(
            inp_nam => 'IRIS',
            par_lst => '{"ore_service_level":"MEDIUM", "ore_parallel_flag":true}',
            out_fmt => '{"Species":"VARCHAR2(10)", "Count":"NUMBER"}',
            grp_col => 'Species',
            scr_name => 'groupCount'));Species Count 
setosa 50 
versicolor 50 
virginica 50Parent topic: Embedded R Execution Functions (Autonomous AI Database)