From 349f2e52e197650caa40309ca285ebe66e9fd995 Mon Sep 17 00:00:00 2001 From: Cesar Hoeflich Date: Fri, 21 May 2021 10:52:29 -0300 Subject: [PATCH] Update listitems-intro.md When performing some queries with CAML Query and keeping the 'p => p.Items' parameters, the complete list return has always occurred. --- docs/using-the-sdk/listitems-intro.md | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/docs/using-the-sdk/listitems-intro.md b/docs/using-the-sdk/listitems-intro.md index 078482dd14..0f0b562a42 100644 --- a/docs/using-the-sdk/listitems-intro.md +++ b/docs/using-the-sdk/listitems-intro.md @@ -42,7 +42,8 @@ SharePoint [CAML](https://docs.microsoft.com/en-us/sharepoint/dev/schema/query-s ```csharp // Assume the fields where not yet loaded, so loading them with the list -var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Items, +// If you are using CAML query, do not use the parameter 'p => p.Items'. It causes full items to load, ignoring the CAML query. +var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Fields.QueryProperties(p => p.InternalName, p => p.FieldTypeKind, p => p.TypeAsString, p => p.Title)); // Build a query that only returns the Title field for items where the Title field starts with "Item1" @@ -80,7 +81,8 @@ By setting a row limit in the CAML query combined with using the the PagingInfo ```csharp // Assume the fields where not yet loaded, so loading them with the list -var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Items, +// If you are using CAML query, do not use the parameter 'p => p.Items'. It causes full items to load, ignoring the CAML query. +var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Fields.QueryProperties(p => p.InternalName, p => p.FieldTypeKind, p => p.TypeAsString, p => p.Title)); // Build a query that only returns the first 20 rows where the Title field starts with "Item1" @@ -132,7 +134,7 @@ Using the [LoadListDataAsStreamAsync method](https://pnp.github.io/pnpcore/api/P ```csharp // Assume the fields where not yet loaded, so loading them with the list -var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Items, +var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Fields.QueryProperties(p => p.InternalName, p => p.FieldTypeKind, p => p.TypeAsString, p => p.Title)); // Build a query that only returns the Title field for the top 5 items where the Title field starts with "Item1" @@ -172,7 +174,7 @@ foreach (var listItem in myList.Items.AsRequested()) ```csharp // Assume the fields where not yet loaded, so loading them with the list -var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Items, +var myList = context.Web.Lists.GetByTitle("My List", p => p.Title, p => p.Fields.QueryProperties(p => p.InternalName, p => p.FieldTypeKind, p => p.TypeAsString, p => p.Title)); // Build a query that only returns the Title field for the first 20 items where the Title field starts with "Item1"