Solved

How to filter generic lists by different algorithms or filter criteria?

Posted on 2010-11-09
3
690 Views
Last Modified: 2013-12-17
We have a situation that extends beyond normal security/permissions where in addition to determining if users have access to certain areas of an application with security principles and identities we need to filter results within sections of the application based on additional values.  Is there a generic way to filter values in a generic list using a different function (e.g. predicate delegates or something similar)?

Example:  Imagine that an application determines if user’s have access to a customer editing screen, but then additionally needs to determine which Customers the user has access to view based on a variety of criteria (e.g. by the Company the customer belongs to, by the Region, by the Customer Level, etc.).  Then imagine that on another section of the application you need to do this same type of filtering of the data that the user can see or edit using different objects and criteria and the filtering cannot be done in the WHERE clause of select statements (e.g. many many pre-existing stored procs that do not use this model).

Take these for example: Filter a List<Person> by peole with the Name == 'John' .  Filter a List<Customer> by customers that have any of the following companies listed for the Company value "Microsoft", "Apple", "Dell" and their Customer Tier is == 2.

  public class Person
    {
        public Person()
        {
            Id = Guid.NewGuid();
        }

        public string Name { get; set; }
        public Guid Id { get; set; }
    }


public class Customer : Person
    {
        public string Company { get; set; }
	public string Region { get; set; }
	public int Tier { get; set; }
    }

Open in new window

0
Comment
Question by:endrec
3 Comments
 
LVL 52

Expert Comment

by:Carl Tawn
Comment Utility
You can use the FindAll() method of a generic List<> to return a new list filtered based on a delegate.
0
 
LVL 16

Accepted Solution

by:
BurnieP earned 500 total points
Comment Utility
You can use lambda expression to filter your results :



List<Person> oPersonList = GetPersonList();

oPersonList = oPersonList .Where(c => c.Name == "John").ToList();



List<Customer> oCustomerList = GetCustomerList();

oCustomerList = oCustomerList.Where((c => c.Company == "Microsoft" || c.Company == "Apple" || c.Company == "Dell") && c.CustomerTier == 2)).ToList();

Open in new window

0
 
LVL 21

Expert Comment

by:Alpesh Patel
Comment Utility
There are different functions to short/ find particular element from List. l.e Select, Find, FindAll etc.
0

Featured Post

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

Recently while returning home from work my wife (another .NET developer) was murmuring something. On further poking she said that she has been assigned a task where she has to serialize and deserialize objects and she is afraid of serialization. Wha…
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
In this seventh video of the Xpdf series, we discuss and demonstrate the PDFfonts utility, which lists all the fonts used in a PDF file. It does this via a command line interface, making it suitable for use in programs, scripts, batch files — any pl…
This video shows how to remove a single email address from the Outlook 2010 Auto Suggestion memory. NOTE: For Outlook 2016 and 2013 perform the exact same steps. Open a new email: Click the New email button in Outlook. Start typing the address: …

744 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

13 Experts available now in Live!

Get 1:1 Help Now