- Release notes
- Before you begin
- Managing access
- Getting started
- Integrations
- Working with process apps- Working with dashboards and charts
- Working with process graphs
- Working with Discover process models and Import BPMN models
- Showing or hiding the menu
- Context information
- Export
- Filters
- Sending automation ideas to UiPath® Automation Hub
- Tags
- Due dates
- Compare
- Conformance checking
- Process simulation
- Root cause analysis
- Simulating automation potential
- Starting a Task Mining project from Process Mining
- Triggering an automation from a process app
- Viewing Process data
 
- Creating apps
- Loading data
- Transforming data- Structure of transformations
- Tips for writing SQL
- Exporting and importing transformations
- Viewing the data run logs
- Merging event logs
- Configuring Tags
- Configuring Due dates
- Configuring fields for Automation potential
- Activity Configuration: Defining activity order
- Making the transformations available in dashboards
 
- Data models
- Adding and editing processes
 
- Customizing process apps
- Publishing process apps
- App templates
- Notifications
- Additional resources

Process Mining
In a local development environment, transformations are run on SQL Server, while Snowflake is used in Process Mining Automation CloudTM. Although most SQL statements will work both on SQL Server and Snowflake, there can be slight differences in syntax, which may lead to different return results.
To write SQL statements that work on both database systems:
- Write field names in double quotes, e.g. Table."Field".
- 
                     Prevent using SQL functions that are different in Snowflake and SQL Server, e.g.string_agg()andlistagg().Thepm_utilspackage comes with a set of functions that work on both database types, refer to Multiple databases. For example, instead of usingstring_agg()orlistagg(), thepm_utils.string_agg()will result in the same behavior for both databases. Ifpm_utilsdoes not contain the desired function, then a Jinja statement should be created to make sure the right function is called on each database.
pm_utils.concat() function. This will yield the same results for both SQL Server and Snowflake.
               pm_utils.concat("This is a nice string", null) = "This is a nice string" Concatenating strings should not be done with operators like + or ||, as they are different for both databases (Snowflake uses || and SQL Server uses +). Also the standard concat() function has different behavior on both systems:
               | SQL Server | Snowflake | 
|---|---|
| nullvalues will be ignored and treated as an empty string. | nullvalues will cause the entire result to benull. | 
Sorting is handled differently in Snowflake and SQL server.
... order by "Attribute_1" desc, "Attribute_2" ...Null values
| SQL Server | Snowflake | 
|---|---|
| nullwill default be sorted first (ascending) | nullwill default be sorted last (ascending) | 
Handling capital letters
| SQL Server | Snowflake | 
|---|---|
| capitals are sorted as expected (AaBbCc) | first sorts by capitals, then by non-capitals (ABCabc) | 
Dashes
-Accountant-| SQL Server | Snowflake | 
|---|---|
| dashes are ignored in sorting (so '-Accountant-' is treated same as 'Accountant') | dashes will be sorted at the top | 
When you group by values “A“ and “ A“, this is seen as one value in SQL Server, but as two different values in Snowflake. Therefore trimming is advised if your data may cause this issue.
Table."Field" = "Some_value" and Table."Field" = "SOME_VALUE" will return the same result set in SQL Server, but potentially two different result sets in Snowflake.
               You are advised to change the behavior of your local SQL Server database to match Snowflakes behavior, to prevent any problems. This can be accomplished by setting the database collation to a case sensitive value.