Using Transaction Steps
  • 11 Oct 2021
  • 2 Minutes to read
  • Dark
    Light
  This documentation version is deprecated, please click here for the latest version.

Using Transaction Steps

  • Dark
    Light

Article summary

Overview

Transaction steps are used when developers want to perform multiple database operations. These steps ensure that the database operations occur either in their entirety or don't occur at all. This example will create a Flow that uses Transaction steps to alter a Customer Info table. There is already a report of all customer details and an action designed to edit the customer information.

Example

  1. Within a Designer Folder, select CREATE FLOW. 
  2. Name the Flow and select CREATE.
  3. Add an Edit Customer Information Form to the workspace. This Form displays all customer details that are available to edit. 
  4. After this Form, place three Transaction Steps onto the Flow by navigating to Integration > Database.
  5. Select the Start Transaction, Commit Transaction, and Rollback Transaction steps found under the database holding the table to edit.

  6. Place the Start Transaction step after the Edit Customer Information Form, followed by the Commit Transaction step. 
  7. The steps placed between these two will be the action taken and committed to the database.

    2019-07-12_090125.PNG

  8. The Start Transaction step allows the isolation level to be specified under the step's Input properties. 
    For assistance on setting transaction isolation levels in SQL, please read the Set Transaction Isolation Levels Microsoft Document.
    Isolation LevelDescription
    Read Uncommitted
    Lowest isolation level. A transaction may read uncommitted changes made by another transaction because they are not isolated from each other.
    Read Committed
    Locks are placed on the data being read, but it can be changed before the end of the Transaction, resulting in non-repeatable reads or phantom data.
    Repeatable Read
    This holds read locks on all rows it references and writes locks on all rows it inserts, updates, or deletes. This prevents non-repeatable reads.
    SerializableA lock is placed on the data to prevent other users from editing it while the Transaction is taking place.
    ChaosBehaves the same way as Read Uncommitted but checks the isolation level of other pending transactions during a write to respect more restrictive isolation levels.
    SnapshotThis choice uses a version of the data at the start of the Transaction, so you cannot see changes by other transactions happening at the same time. This choice offers the benefit of reduced blocking. The Snapshot value uses Snapshot Isolation if the ALLOW_SNAPSHOT_ISOLATION ON database option has been set, by a DBA, in the SQL Server database.
    UnspecifiedA different, undetermined isolation level is being used.
  9. To edit the Customer Information table, place the Edit CustomerInfo step between the Start Transaction and Commit Transaction steps.

    2019-07-12_090139.PNG

  10. If the Transaction fails, rollback the changes to the table before starting the Transaction.
  11. To do this, select the Commit Transaction step and navigate to the properties tab on the right side. 
  12. Under outcomes, choose the option to Add Outcome for Exception.

  13. Add the Rollback Transaction step to the outcome path generated from this selection. 
  14. Connect both the Rollback Transaction step and the Commit Transaction step to the end step to complete the Flow. 
  15. Test the Flow by selecting a customer from the Report and successfully updating the address.

    2019-07-12_090219.PNG


Was this article helpful?