Below approach is used when user wants to perform pagination based on given parameters. In order to make paging work, you need to get page index and recurring count values from user.
Suppose if you are trying to get list items from 100 to 200 then assign PageIndex =2 and recCount =100 into the following method.
//Add client
Please have a look at Authentication post for more details about SharePoint Client object model authentication.
List Items can be retrive in result and user can specify PageIndex and RecCount values which will be used for resulting certain number of values.
If your list is having more than 1 million and user requested only for list items in the rage of 100-200 then it is not good practice to get all list item collection. To avoid to load all list items collection you need to get required list item from CAML and using Paging. The logic is :
- Calculate skip value
- Assign skip values to ListItemCollectionPosition PagingInfo e.g. “Paged=TRUE&p_ID=SKIP_NUMBER”
- Pass ListItemCollectionPosition value to CAML query
- Apply RowLimit value to CAML query
Suppose if you are trying to get list items from 100 to 200 then assign PageIndex =2 and recCount =100 into the following method.
//Add client
using SP = Microsoft.SharePoint.Client;
public void getItems(int pageIndex, int recCount)
{
SP.ClientContext ctx = getClientContext(); //authenticate client context
// first,
if (ctx != null)
{
int iSkip = pageIndex * recCount - recCount;
SP.List list = ctx.Web.Lists.GetByTitle("Your LIst
Name"); // replace with your list name
ListItemCollectionPosition itemPosition = new ListItemCollectionPosition();
itemPosition.PagingInfo = string.Format("Paged=TRUE&p_ID={0}",iSkip);
CamlQuery camlQuery = new CamlQuery();
camlQuery.ListItemCollectionPosition = itemPosition;
camlQuery.ViewXml = @"<View><ViewFields>
<FieldRef Name='ID'/>
<FieldRef Name='Title'/>
</ViewFields><RowLimit>" + recCount + @"</RowLimit>
</View>";
SP.ListItemCollection listItems = list.GetItems(camlQuery);
ctx.Load(listItems);
ctx.ExecuteQuery();
foreach (SP.ListItem listItem in listItems)
{
//Do forward with
listItem["ID"].ToString() and
listItem["Name"].ToString()
}
}
}
|
Please have a look at Authentication post for more details about SharePoint Client object model authentication.
hey..hi..will you please post something that will we useful for beginners...
ReplyDeleteYes, very soon I will publish more posts..
ReplyDeletehi I am hacking around a similar solution... got huge problems when involving OrderBy in the caml query... then your approach renders useless ;) ... keep up good work
ReplyDeleteThis Looks good, but where are the user controls ( Next , Prev etc....)?
ReplyDeleteHi,
ReplyDeleteI was looking for soemthing like this, but this looks wrong to me.
What you're skipping are the first "iSkip" ID's not the first "iSkip" rows.
So if someone deletes a row, or the ID's dont start off with 1 (and are consistently increased by 1) - this will result in unwanted behavior.
Id != RowNumber
Paged=TRUE&p_ID={}
Deletethis will take first given rows only. Means iSkip = 10 then it would return listitmes only after 10 rows, It wont returns by list item Id number.
this always return the same result for every pageIndex
ReplyDeleteHi Niteen Badgujar,
ReplyDeletei using this code, but it always return the same result set for every pageIndex