Manage Your Picklist Values

Are you still thinking about cookies from that last challenge? There are so many flavors of cookies in the world. If you’re running a cookie company, you want to standardize your flavor names. Are your cinnamon cookies called “snickerdoodles”? Once you pick the name, you want to make sure your orders, and other records, always use the same name.

We show you how to get smart about how you set the values for picklists. Good picklist value management saves you time and helps keep the data in your org consistent.

Where You Set Picklist Values

Picklists are fields associated with individual objects. You set and manage picklists in the same place you add or manage other fields: an object’s Fields & Relationships page. When you created your picklist in the last unit, you set its initial values. Let’s go back and look at a Fields & Relationships page.

The Fields & Relationships page of the Product object

What does “Indexed” mean? The page of Fields & Relationships identifies some fields, including some picklists, as indexed and you’re probably wondering what that means. An indexed field is stored in the database in a way that supports quick retrieval. This optimizes report generation, list views, and other requests…sometimes. What makes a good index candidate is pretty advanced. Salesforce automatically analyzes performance and periodically assigns fields to be indexed. You don’t have to think about this while you’re creating picklists, but it can be important later if you’re trying to optimize report or org performance.

Manage Picklist Values

Time to start tinkering with the values.

  1. In Setup, click the Object Manager tab, and then select the object associated with your picklist field.
  2. Click Fields & Relationships.
  3. Click the picklist’s Field Label to see the field’s detail page. You see your values in the Values related list

Your picklist values in the Values related list

You have a few options on this page:

Remember, sometimes standard picklist fields share a standard value set. When you change a value in that set, the change also appears in other standard picklist fields that use the same values. For example, the Lead Source and Account Source standard picklist fields share the same value set. Change standard picklist field values carefully.

Active, Inactive, Deleted, and Replaced Values

In the Values related list on the detail page, you can edit, delete, or deactivate individual values. You can probably guess the difference between an active value and an inactive one. Active values appear as an option in a picklist. Inactive values don’t, but they’re not entirely removed from your org.

When is this helpful? Think about your delicious pumpkin cookies. They aren’t popular in summer, so you set that value to inactive all summer. In the fall, customers want pumpkin-flavored everything, so you start making pumpkin cookies and set the value to active, again.

But sometimes you really no longer need a value. You tried selling spinach cookies. Surprisingly, these were not a hit with your customers, so you delete that value.

Some important things to know about inactive values:

Important things to know about deleting/replacing values:

Edit Picklist Values

Let’s look at the Values related list.

Displaying more than one value selected

On the field’s detail page, click Edit to see more options for a single value.

Displaying more than one value selected

And you can make any of the following changes:

Why a Picklist Value’s API Name Is Important

It’s easy to overlook the API name because it’s auto-populated when you create the field. But this value is incredibly powerful. The API name is a unique identifier for a value, even when the label changes.

Since the Spring ’17 release, picklist values are assigned an API name, which is a reference to the value, as well as a label, which is what shows in the UI. The API name allows formulas and custom apps to refer to a picklist value, even if the field name changes.

Imagine writing a formula, or customizing an app that refers to a picklist label value (as admins and devs had to do before Spring ’17). Then the picklist value changes, and now the formula or reference to that value is no longer valid. Change happens. But, references to the API name continue to be valid, no matter the label value. And you can prevent the API name from changing to ensure references to the field’s value won’t become invalid, later.

Controlling Fields, Dependent Picklists, and Narrowing Values

As we discussed in the previous unit, dependent picklist fields narrow the available values based on a selection in a controlling field. For example, the user selects “nut free” in a controlling field, and only cookie flavors that don’t have nuts show in the dependent picklist field.

The controlling field doesn’t have to be a picklist. It can also be a checkbox.

Controlling field is a checkbox example

To set a dependent picklist field:

  1. From the management settings for the object you want to add a field to, click Fields & Relationships.
  2. Click Field Dependencies.
  3. Click New.
  4. Choose a controlling field and dependent field.
  5. Click Continue.
  6. Use the field dependency matrix to specify which dependent picklist values are available when a user selects each controlling field value.
  7. Optionally, click Preview to test your selections.
  8. Click Save.

Some things to consider:

Use Formulas for Default Picklist Values

Now that you’ve got the basics, let’s assign a dynamic default value. This means, based on certain conditions and values from other fields, the picklist’s default value changes. Setting the right default can speed data entry.

For example, you can change the default value for a field based on the profile of the person viewing the field. Or if a customer’s total cookie purchases are above a certain number, their frequent customer status changes.

  1. In Setup, click the Object Manager tab, and then select the object associated with your picklist field.
  2. Click Fields & Relationships.
  3. Click Edit next to the picklist field.

Where to select Edit on an existing picklist field

  1. Add your formula under General Options.

Where to enter formulas

It’s super helpful to click Show Formula Editor so you have more space.

More importantly, the Formula Editor lets you check your syntax and gives you picklists (Yay picklists!) to suggest fields, operators, and functions for your formula.

Define something for the value default in case the formula doesn’t resolve to an active value. For example, the following is a formula to set an Opportunity priority to High for all users in the Fast Response Sales profile. Otherwise, the value is Standard.

IF($Profile.Name = "Fast Response Sales", "High", "Standard")

If you want the field to remain blank when the user isn’t in the Fast Response Sales profile, use:

IF($Profile.Name = "Fast Response Sales", "High", null)

Change the Field Type to Allow/Prevent Multi-Selection

With all the options for picklist fields, rest assured you can change the field type when necessary. For example, if you have a custom picklist field and decide you want to make it a multi-select picklist, you can do that.

  1. In Setup, click the Object Manager tab, and then select the object associated with your picklist field.
  2. Click Fields & Relationships.
  3. Click Edit next to the picklist field.
  4. Select Change Field Type.

Change Field Type button on the picklist field Edit page

Inactive values will be lost.

And vice-versa. You can convert a multi-select picklist to a custom picklist that doesn’t allow multi-selection by changing the field type.

When you change a multi-select picklist to a picklist that doesn’t allow multi-selection, Salesforce clears the values for that field on existing records. This makes sense, right? Because the field now only allows one value.

You can see that you have a lot of flexibility managing picklist values, and even the type of picklist to use. You can start with one type of picklist and switch to another, or change the behavior of the values in a picklist. It helps that you don’t have to have it all figured out in advance. Change the picklist properties to meet your needs. In the next unit, you learn to share picklist values with more than one picklist.

Resources