This project is read-only.


The LINQ to SharePoint project provides a custom query provider for LINQ that allows to query SharePoint lists using familiar LINQ syntax. LINQ stands for Language Integrated Query and is one of the core features of Microsoft's .NET Framework 3.5 release. More information can be found via the MSDN website on

Visit our team blog at Also check out this Channel 9 geekSpeak video.


  • Custom query provider that translates LINQ queries to CAML, the Collaborative Application Markup Language used by SharePoint for querying.
  • Support for LINQ in C# 3.0 and Visual Basic 9.0.
  • Entity creation tool SpMetal to export SharePoint list definitions to entity classes used for querying.
  • Visual Studio 2008 integration for entity creation (a.k.a. SPML).
  • Can connect to a SharePoint site either using the SharePoint object model or via the SharePoint web services.
  • Planned support for updating through entity types.


  • 11/29/2007 - v0.2.4.0 alpha release for .NET Framework 3.5 and Visual Studio 2008 RTM (release bulletin)
  • 08/13/2007 - v0.2.3.0 alpha release available for Orcas Beta 2 (release bulletin).
  • 08/01/2007 - Sources updated for Orcas Beta 2. A new release targeting Orcas Beta 2 will be provided soon.
  • 07/20/2007 - v0.2.2.0 alpha release available for Orcas Beta 1 (release bulletin).
  • 07/06/2007 - We're currently working on an interim release that focuses on code maintainability and some design changes to enable the 0.3 update feature set. This interim release will be the first to cover SPML and Visual Studio 2008 integration with a code generator and an improved debugger visualizer.
  • 06/30/2007 - v0.2.0.0 alpha release available for Orcas Beta 1 (release bulletin).
  • 06/08/2007 - The 0.2 release is planned to become available later this month; the (draft of the) technical spec is now under source control too (/Specs folder).
  • 05/04/2007 - Work has started on the 0.2 release. The 0.2 release will cover enhanced support for different field types in SharePoint, including Lookup fields, and extended overall test coverage.
  • 04/23/2007 - v0.1.2.0 alpha release available for Orcas March 2007 CTP (update for Beta 1 coming soon).


For a list of samples and a quick-start guide, see Samples.

C# sample

    // updated for the alpha release
    var ctx = new SharePointDataContext(new Uri("http://wss.mycompany.local"));
    ctx.Log = Console.Out;
    var users = ctx.GetList<Users>(ctx);

    var res = from u in users
              orderby u.Birthdate descending
              where u.FirstName.StartsWith("B") && u.Age >= 24 && u.FavoriteFood == FavoriteFood.Pizza
              select new { u.FullName, u.Age, Interest = u.AccountBalance * 0.07 };

    foreach (var u in res)

Visual Basic sample

    ' updated for the alpha release
    Dim context As New SharePointDataContext(New Uri("http://wss.mycompany.local"))
    context.Log = Console.Out
    Dim users = context.GetList(Of User)()

    Dim res = From u In users _
              Order By u.Birthdate Descending _
              Where u.FirstName.StartsWith("B") And u.Age >= 24 And u.FavoriteFood.Value = FavoriteFood.Pizza _
              Select u.FullName, u.Age, Interest = u.AccountBalance.Value * 0.07

    For Each u In res

About the project founder

A former Visual C# MVP, Bart De Smet now works at Microsoft Corporation on the WPF dev team in an SDE role. Prior to this new challenge, Bart was active in the Belgian community evangelizing various Microsoft technologies, most of the time focusing on CLR, language innovation and frameworks. In his evangelism role, he's been speaking at various events and attended several international conferences including TechEd Europe, IT Forum and the PDC. In 2005, Bart graduated as a Master of Informatics from Ghent University, Belgium. Two years later, Bart became a Master of Computer Science Software Engineering from the same university.

You can visit Bart's blog on

Last edited Nov 29, 2007 at 8:37 AM by bdesmet, version 33