Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

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

Posted on 2010-11-09
3
Medium Priority
?
701 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
ID: 34096801
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 2000 total points
ID: 34098217
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
ID: 34101607
There are different functions to short/ find particular element from List. l.e Select, Find, FindAll etc.
0

Featured Post

Veeam and MySQL: How to Perform Backup & Recovery

MySQL and the MariaDB variant are among the most used databases in Linux environments, and many critical applications support their data on them. Watch this recorded webinar to find out how Veeam Backup & Replication allows you to get consistent backups of MySQL databases.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
The article shows the basic steps of integrating an HTML theme template into an ASP.NET MVC project
This Micro Tutorial will teach you how to add a cinematic look to any film or video out there. There are very few simple steps that you will follow to do so. This will be demonstrated using Adobe Premiere Pro CS6.
Video by: ITPro.TV
In this episode Don builds upon the troubleshooting techniques by demonstrating how to properly monitor a vSphere deployment to detect problems before they occur. He begins the show using tools found within the vSphere suite as ends the show demonst…
Suggested Courses

877 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