Umbraco Forms in the Database
In Umbraco Forms, it is only possible to store Form data in the database.
If you are upgrading to Umbraco 9 or later and using Forms, you should first migrate the Forms to the database using Forms 8. As of Umbraco Forms version 8.5.0 it is possible to persist all Forms data in the Umbraco database. This includes definitions for each Form and their fields, as well as workflow definitions and prevalues.
Enable storing Forms definitions in the database
To persist Umbraco Forms definitions in the database, follow these steps:
- Upgrade to at least Umbraco Forms version 8.5.2. 
- Open the configuration file - App_Plugins\UmbracoForms\UmbracoForms.config.
- Locate the - StoreUmbracoFormsInDbkey in the- <settings>section, and make sure it has the following value:- <setting key="StoreUmbracoFormsInDb" value="True" />
- Save the file. 
If you are working with a Umbraco Cloud project, make sure you follow the migration steps outlined in the Umbraco Forms on Cloud article.
Enabling the persisting of Umbraco Forms in the database is irreversible. Once you've made the change, reverting to the file approach will not be an option.
When you save the file, the site will restart and run a migration step, migrating the files to the Umbraco database.
Migrating Forms in files into a site
You can force Forms to rerun the migration of the file-format Forms if you have a Umbraco 8 site storing Forms in the database.
First of all, you should ensure that you have enabled the setting that persists Forms in the database, as the migration requires this (StoreUmbracoFormsInDb) key. We highly recommend testing this on a local setup before applying it to your live site.
- Copy over the Forms, workflows, prevaluesources, and datasource files to the site into - ~\App_Data\UmbracoForms\Data.
- Go to the database and find the - [umbracoKeyValue]table.
- Find the Form's row and check that the value is - 1d084819-84ba-4ac7-b152-2c3d167d22bc(if not you are not currently working with Forms in the database, changing the setting should be enough).
- Change that value to - {forms-init-complete}.
- Restart the site. 
The site will now try to migrate the Forms files into the database. In the umbracoTraceLog, you can follow the progress. It will throw errors if anything goes wrong. Additionally, it will log out "The Umbraco Forms DB table {TableName} already exists" for the 4 Forms tables before starting the migration.
Last updated
Was this helpful?
