Required Lookup

Table of Contents

Today I had a requirement to make a lookup field required and set the default value. For a lookup field this isn’t possible within the SharePoint 2010 interface.

My solution

Programmatically the SPFieldLookup also doesn’t have the options available. However casting the Lookup to an SPField does the trick.

public overridevoid FeatureActivated(SPFeatureReceiverProperties properties)
SPWeb web = (SPWeb)properties.Feature.Parent;
SPList list = web.Lists["MyList"];
SPField lookup = (SPField)list.Fields["My Lookup"];

lookup.DefaultValue = "1;#Value 1";
lookup.Required = true;
catch(Exception Ex)
// do what ever you want
Avatar for Pieter Veenstra

By Pieter Veenstra

Business Applications Microsoft MVP working as a Principal Architect at HybrIT Services Ltd. You can contact me using

4 thoughts on “Making a required lookup and setting the default value in SharePoint 2013”
    1. Hi Adrian,

      You would need to do this in a feature receiver. So you will need to Create a new feature in Visual Studio and add the code in this post to the FeatureActivated method.

      Are you happy using Visual Studio or is this something you need help with?


      1. I’ll try with VS, I was hoping for a non-deploy solution. Such as one that could be placed in a CEWP

      2. I guess it is just as easy to use PowerShell.

        How about something like this:

        web = Get-SPWeb $webUrl
        list = web.Lists.TryGetList("MyList")
        lookup = [Microsoft.SharePoint.SPField]list.Fields["My Lookup"]

        lookup.DefaultValue = "1;#Value 1"
        lookup.Required = true

        I didn’t test the above code but it should be ok.

Leave a Reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Discover more from SharePains by Microsoft MVP Pieter Veenstra

Subscribe now to keep reading and get access to the full archive.

Continue Reading