Loading...

Multi-select choices and Dataverse storage

Image
Multi-select choices and Dataverse storage Stephane Pelhatre Thu, 03/14/2024 - 18:51
Body

Introduction

You're probably familiar with the "Choice" data type in Power Apps which allows you to select a single item from a drop-down list.

You may also be familiar with multi-select column (called Choices) which allows you to select multiple items in a drop-down list.

While a single Choice column is stored in the underlying Azure SQL database as 2 fields (one for the label and another for the value), what about the storage of a multiple-select column?

You will have the answer in this article.

Summary of Choices column features

When you add a multi-select column, you can specify multiple values that will be available for users to select. When users fill out the form they can select one, multiple, or all the values displayed in a drop-down list.

Multi-select columns can be used with read-only grids, editable grids, and most forms. But they have several limitations and can't be used with:

  • Workflows
  • Business process flows
  • Actions
  • Dialogs
  • Business rules
  • Charts
  • Rollup columns or calculated columns.

See below a Choices field in  a form:

form display

 

Choices field with the focus inside:

field display 2

 

Choices field with no focus inside. Note that items are separated by a comma.

field 1

 

You can also add a Choices column in a view. Note that items are separated by a semicolon.

view

 

Enable TDS endpoint

To be able to see how a multi-select column is stored in the underlying Azure SQL database, you must enable the TDS endpoint (Tabular Data Stream) for your Dataverse environment.

You can read the following articles on TDS:

In summary:

Go to admin.powerplatform.microsoft.com and select your environment  

Then click on Settings and navigate to Product > Features

admin_feature

 

Check that TDS endpoint is activated

TDS

Storage in Azure SQL database

To illustrate the storage of a multiple-select column I created 2 columns in my Dataverse environment: the 2 columns have the 'Choice' type but one has the multi-select option activated and the other does not.

  • Column with logical name = 'elca_singlehobby' : Choice column with the multi-select option disabled
  • Column with logical name = 'elca_hobbies' : Choice column with the multi-select option enabled

Then with SQL Server Management Studio (SSMS) we can connect to the database and view the result of the storage of the 2 columns :

SQL fields

As you can see 2 fields are created in the SQL database to store the column 'elca_singlehobby': one field with the type int and another field with the type nvarchar .

And for the multi-select column 'elca_hobbies' only one field of type nvarchar is created in the SQL database.

We can see the values of the fields in the SQL database by running a simple SQL query:

SQL query

 

We can see that the muti-select value is the list of values separated by commas.

What about Azure Synapse Link?

And if you try to retrieve a multi-select column with Azure Synapse Link, what will you get?

As you can see below you will get the list of values ... but separated by semicolons.

Synapse

 

    Learn more
    Author image

    Featured Articles | Dynamics Chronicles

    Welcome to our blog, the content is entirely dedicated to Microsoft Dynamics 365, CRM, Power Platform, Common Data Service (CDS) but also Azure. Follow us !

    Share post:

    Related

    Stay up to date with latest Microsoft Dynamics 365 and Power Platform news!

    * Yes, I agree to the privacy policy