Linq expression filter in IQueryable Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live! The [wrap] tag is in the process of being burninatedLINQ query on a DataTableDynamic LINQ OrderBy on IEnumerable<T> / IQueryable<T>Multiple “order by” in LINQWhy would you use Expression<Func<T>> rather than Func<T>?When to use .First and when to use .FirstOrDefault with LINQ?What is the Java equivalent for LINQ?Returning IEnumerable<T> vs. IQueryable<T>LINQ Aggregate algorithm explainedGroup by in LINQWhat is a lambda expression in C++11?

Denied boarding although I have proper visa and documentation. To whom should I make a complaint?

Did MS DOS itself ever use blinking text?

What is this building called? (It was built in 2002)

Do I really need to have a message in a novel to appeal to readers?

Would "destroying" Wurmcoil Engine prevent its tokens from being created?

What does "lightly crushed" mean for cardamon pods?

Fundamental Solution of the Pell Equation

Can anything be seen from the center of the Boötes void? How dark would it be?

Using et al. for a last / senior author rather than for a first author

How to react to hostile behavior from a senior developer?

Can you use the Shield Master feat to shove someone before you make an attack by using a Readied action?

How to show element name in portuguese using elements package?

Maximum summed powersets with non-adjacent items

Most bit efficient text communication method?

Irreducible of finite Krull dimension implies quasi-compact?

How to down pick a chord with skipped strings?

Do wooden building fires get hotter than 600°C?

Why wasn't DOSKEY integrated with COMMAND.COM?

How can I use the Python library networkx from Mathematica?

Closed form of recurrent arithmetic series summation

Is there a holomorphic function on open unit disc with this property?

What is the meaning of the simile “quick as silk”?

Is there such thing as an Availability Group failover trigger?

For a new assistant professor in CS, how to build/manage a publication pipeline



Linq expression filter in IQueryable



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)
Data science time! April 2019 and salary with experience
The Ask Question Wizard is Live!
The [wrap] tag is in the process of being burninatedLINQ query on a DataTableDynamic LINQ OrderBy on IEnumerable<T> / IQueryable<T>Multiple “order by” in LINQWhy would you use Expression<Func<T>> rather than Func<T>?When to use .First and when to use .FirstOrDefault with LINQ?What is the Java equivalent for LINQ?Returning IEnumerable<T> vs. IQueryable<T>LINQ Aggregate algorithm explainedGroup by in LINQWhat is a lambda expression in C++11?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








0















I want to create generic expression filtering in IQueryable



public class Vehicle

public int Id get; set;
public string VehicleNO get; set;
public int DriverId get; set;
public Driver Driver get;set;


public class Driver

public int Id get; set;
public string Name get; set;




operator = "Contain", field name = "Driver.Name", Value filter =
"Micheal"




I don't know how to filter driver name.
Here is my full code



IQueryable<SysClientSiteUser> query = entity.SysClientSiteUsers.Include(i => i.SysClientSiteRole);

Dictionary<string, string> dtFilter = new Dictionary<string, string>();
dtFilter.Add("VehicleNo", "A123");


Dictionary<Type, Func<string, object>> lookup = new Dictionary<Type, Func<string, object>>();


lookup.Add(typeof(string), x => return x; );
lookup.Add(typeof(long), x => return long.Parse(x); );
lookup.Add(typeof(int), x => return int.Parse(x); );
lookup.Add(typeof(double), x => return double.Parse(x); );

var paramExpr = Expression.Parameter(typeof(Vehicle), "VehicleNo");

var keyPropExpr = Expression.Property(paramExpr, "VehicleNo");

if (!lookup.ContainsKey(keyPropExpr.Type))
throw new Exception("Unknown type : " + keyPropExpr.Type.ToString());

var typeDelegate = lookup[keyPropExpr.Type];
var constantExp = typeDelegate("A123");
var eqExpr = Expression.Equal(keyPropExpr, Expression.Constant(constantExp));
var condExpr = Expression.Lambda<Func<SysClientSiteUser, bool>>(eqExpr, paramExpr);
query = query.Where(condExpr);


for normal field, it's working. But if I want to call Driver name. it's not work. How to call "Driver.Name"?










share|improve this question
























  • You'll need Expression.Property(Expression.Property(paramExpr, "Driver"), "Name").

    – canton7
    Mar 22 at 10:19

















0















I want to create generic expression filtering in IQueryable



public class Vehicle

public int Id get; set;
public string VehicleNO get; set;
public int DriverId get; set;
public Driver Driver get;set;


public class Driver

public int Id get; set;
public string Name get; set;




operator = "Contain", field name = "Driver.Name", Value filter =
"Micheal"




I don't know how to filter driver name.
Here is my full code



IQueryable<SysClientSiteUser> query = entity.SysClientSiteUsers.Include(i => i.SysClientSiteRole);

Dictionary<string, string> dtFilter = new Dictionary<string, string>();
dtFilter.Add("VehicleNo", "A123");


Dictionary<Type, Func<string, object>> lookup = new Dictionary<Type, Func<string, object>>();


lookup.Add(typeof(string), x => return x; );
lookup.Add(typeof(long), x => return long.Parse(x); );
lookup.Add(typeof(int), x => return int.Parse(x); );
lookup.Add(typeof(double), x => return double.Parse(x); );

var paramExpr = Expression.Parameter(typeof(Vehicle), "VehicleNo");

var keyPropExpr = Expression.Property(paramExpr, "VehicleNo");

if (!lookup.ContainsKey(keyPropExpr.Type))
throw new Exception("Unknown type : " + keyPropExpr.Type.ToString());

var typeDelegate = lookup[keyPropExpr.Type];
var constantExp = typeDelegate("A123");
var eqExpr = Expression.Equal(keyPropExpr, Expression.Constant(constantExp));
var condExpr = Expression.Lambda<Func<SysClientSiteUser, bool>>(eqExpr, paramExpr);
query = query.Where(condExpr);


for normal field, it's working. But if I want to call Driver name. it's not work. How to call "Driver.Name"?










share|improve this question
























  • You'll need Expression.Property(Expression.Property(paramExpr, "Driver"), "Name").

    – canton7
    Mar 22 at 10:19













0












0








0








I want to create generic expression filtering in IQueryable



public class Vehicle

public int Id get; set;
public string VehicleNO get; set;
public int DriverId get; set;
public Driver Driver get;set;


public class Driver

public int Id get; set;
public string Name get; set;




operator = "Contain", field name = "Driver.Name", Value filter =
"Micheal"




I don't know how to filter driver name.
Here is my full code



IQueryable<SysClientSiteUser> query = entity.SysClientSiteUsers.Include(i => i.SysClientSiteRole);

Dictionary<string, string> dtFilter = new Dictionary<string, string>();
dtFilter.Add("VehicleNo", "A123");


Dictionary<Type, Func<string, object>> lookup = new Dictionary<Type, Func<string, object>>();


lookup.Add(typeof(string), x => return x; );
lookup.Add(typeof(long), x => return long.Parse(x); );
lookup.Add(typeof(int), x => return int.Parse(x); );
lookup.Add(typeof(double), x => return double.Parse(x); );

var paramExpr = Expression.Parameter(typeof(Vehicle), "VehicleNo");

var keyPropExpr = Expression.Property(paramExpr, "VehicleNo");

if (!lookup.ContainsKey(keyPropExpr.Type))
throw new Exception("Unknown type : " + keyPropExpr.Type.ToString());

var typeDelegate = lookup[keyPropExpr.Type];
var constantExp = typeDelegate("A123");
var eqExpr = Expression.Equal(keyPropExpr, Expression.Constant(constantExp));
var condExpr = Expression.Lambda<Func<SysClientSiteUser, bool>>(eqExpr, paramExpr);
query = query.Where(condExpr);


for normal field, it's working. But if I want to call Driver name. it's not work. How to call "Driver.Name"?










share|improve this question
















I want to create generic expression filtering in IQueryable



public class Vehicle

public int Id get; set;
public string VehicleNO get; set;
public int DriverId get; set;
public Driver Driver get;set;


public class Driver

public int Id get; set;
public string Name get; set;




operator = "Contain", field name = "Driver.Name", Value filter =
"Micheal"




I don't know how to filter driver name.
Here is my full code



IQueryable<SysClientSiteUser> query = entity.SysClientSiteUsers.Include(i => i.SysClientSiteRole);

Dictionary<string, string> dtFilter = new Dictionary<string, string>();
dtFilter.Add("VehicleNo", "A123");


Dictionary<Type, Func<string, object>> lookup = new Dictionary<Type, Func<string, object>>();


lookup.Add(typeof(string), x => return x; );
lookup.Add(typeof(long), x => return long.Parse(x); );
lookup.Add(typeof(int), x => return int.Parse(x); );
lookup.Add(typeof(double), x => return double.Parse(x); );

var paramExpr = Expression.Parameter(typeof(Vehicle), "VehicleNo");

var keyPropExpr = Expression.Property(paramExpr, "VehicleNo");

if (!lookup.ContainsKey(keyPropExpr.Type))
throw new Exception("Unknown type : " + keyPropExpr.Type.ToString());

var typeDelegate = lookup[keyPropExpr.Type];
var constantExp = typeDelegate("A123");
var eqExpr = Expression.Equal(keyPropExpr, Expression.Constant(constantExp));
var condExpr = Expression.Lambda<Func<SysClientSiteUser, bool>>(eqExpr, paramExpr);
query = query.Where(condExpr);


for normal field, it's working. But if I want to call Driver name. it's not work. How to call "Driver.Name"?







c# linq lambda expression






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Mar 22 at 9:46









NibblyPig

25.6k59152280




25.6k59152280










asked Mar 22 at 9:40









user2156181user2156181

73




73












  • You'll need Expression.Property(Expression.Property(paramExpr, "Driver"), "Name").

    – canton7
    Mar 22 at 10:19

















  • You'll need Expression.Property(Expression.Property(paramExpr, "Driver"), "Name").

    – canton7
    Mar 22 at 10:19
















You'll need Expression.Property(Expression.Property(paramExpr, "Driver"), "Name").

– canton7
Mar 22 at 10:19





You'll need Expression.Property(Expression.Property(paramExpr, "Driver"), "Name").

– canton7
Mar 22 at 10:19












1 Answer
1






active

oldest

votes


















0














You can use a helper function to convert a nested property name string to an Expression that accesses that property for a given ParameterExpression and type:



private static Expression MakePropertyExpression<T>(string propertyName, Expression baseExpr) =>
propertyName.Split('.').Aggregate(baseExpr, (b, pname) => Expression.Property(b, pname));





share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55296747%2flinq-expression-filter-in-iqueryable%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    You can use a helper function to convert a nested property name string to an Expression that accesses that property for a given ParameterExpression and type:



    private static Expression MakePropertyExpression<T>(string propertyName, Expression baseExpr) =>
    propertyName.Split('.').Aggregate(baseExpr, (b, pname) => Expression.Property(b, pname));





    share|improve this answer



























      0














      You can use a helper function to convert a nested property name string to an Expression that accesses that property for a given ParameterExpression and type:



      private static Expression MakePropertyExpression<T>(string propertyName, Expression baseExpr) =>
      propertyName.Split('.').Aggregate(baseExpr, (b, pname) => Expression.Property(b, pname));





      share|improve this answer

























        0












        0








        0







        You can use a helper function to convert a nested property name string to an Expression that accesses that property for a given ParameterExpression and type:



        private static Expression MakePropertyExpression<T>(string propertyName, Expression baseExpr) =>
        propertyName.Split('.').Aggregate(baseExpr, (b, pname) => Expression.Property(b, pname));





        share|improve this answer













        You can use a helper function to convert a nested property name string to an Expression that accesses that property for a given ParameterExpression and type:



        private static Expression MakePropertyExpression<T>(string propertyName, Expression baseExpr) =>
        propertyName.Split('.').Aggregate(baseExpr, (b, pname) => Expression.Property(b, pname));






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Mar 22 at 19:04









        NetMageNetMage

        14.2k12037




        14.2k12037





























            draft saved

            draft discarded
















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55296747%2flinq-expression-filter-in-iqueryable%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            SQL error code 1064 with creating Laravel foreign keysForeign key constraints: When to use ON UPDATE and ON DELETEDropping column with foreign key Laravel error: General error: 1025 Error on renameLaravel SQL Can't create tableLaravel Migration foreign key errorLaravel php artisan migrate:refresh giving a syntax errorSQLSTATE[42S01]: Base table or view already exists or Base table or view already exists: 1050 Tableerror in migrating laravel file to xampp serverSyntax error or access violation: 1064:syntax to use near 'unsigned not null, modelName varchar(191) not null, title varchar(191) not nLaravel cannot create new table field in mysqlLaravel 5.7:Last migration creates table but is not registered in the migration table

            용인 삼성생명 블루밍스 목차 통계 역대 감독 선수단 응원단 경기장 같이 보기 외부 링크 둘러보기 메뉴samsungblueminx.comeh선수 명단용인 삼성생명 블루밍스용인 삼성생명 블루밍스ehsamsungblueminx.comeheheheh

            155 수학 과학 기타 둘러보기 메뉴eh추가해eh문서를 완성해