Solved

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

Posted on 2010-11-09
3
692 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 500 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

Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Question! 4 36
InputLanguage 1 27
VB.NET 2008 - SQL Timeout 9 26
C# LINQ ForEach() question 6 29
This article is for Object-Oriented Programming (OOP) beginners. An Interface contains declarations of events, indexers, methods and/or properties. Any class which implements the Interface should provide the concrete implementation for each Inter…
This article shows how to deploy dynamic backgrounds to computers depending on the aspect ratio of display
This Micro Tutorial will give you a basic overview how to record your screen with Microsoft Expression Encoder. This program is still free and open for the public to download. This will be demonstrated using Microsoft Expression Encoder 4.
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…

825 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