かずきのBlog

C#やJavaやRubyとメモ書き

目次

Blog 利用状況

ニュース

わんくまBlogが不安定になったため、前に書いてたはてなダイアリーにメインを移動します。
かずきのBlog@Hatena
技術的なネタは、こちらにも、はてなへのリンクという形で掲載しますが、雑多ネタははてなダイアリーだけに掲載することが多いと思います。
コメント
プログラマ的自己紹介
お気に入りのツール/IDE
プロフィール
経歴
広告
アクセサリ

書庫

日記カテゴリ

ExpressionTreeを組み立てて見たいのだけど(挫折)

前の記事で、LINQ to SQLのwhere句を動的に組み立てたい!と思ってたけど、LINQ to SQLのwhere句って結局ExpressionTreeになるらしい。
ってことは、ExpressionTreeをガリガリ組み立てれば動的にWhere句作れるんじゃない?と考えた!

挫折した!(早)

だってめんどくさいんだもん。

using (var ctx = new EduDataContext(
    Settings.Default.EmpMngConnectionString))
{
    ctx.Log = Console.Out;

    ParameterExpression param = Expression.Parameter(typeof(Employees), "emp");
    Expression<Func<Employees, bool>> ex = Expression.Lambda<Func<Employees, bool>>(
            Expression.Equal(
                Expression.Property(param, "Name"),
                Expression.Constant(name)),
            param);
    return ctx.Employees.Where(ex).ToArray();
}

どこからか与えられたname変数とEmployeesクラスのNameプロパティの値が等しいか?というだけでもこんな感じ。
これを動的に組み立てるのは超めんどくさそう。

ってことで挫折しましたorz
前の記事のやり方でいく!

# Genericsの<>の中身が消えてたのを修正。

投稿日時 : 2007年11月22日 22:27

Feedback

# re: ExpressionTreeを組み立てて見たいのだけど(挫折) 2007/11/23 10:05 R・田中一郎

>だってめんどくさいんだもん。

うん、面倒くさい。
それに、使い所が今ひとつわからない orz

# re: ExpressionTreeを組み立てて見たいのだけど(挫折) 2007/11/23 10:30 Streetw☆

こんな風に書くんですか。¢(. .。)メモメモ
#ソース内のFUNCの辺りとか消えちゃってますね。
早速してみたら、私のクラスでは項目をプロパティじゃなくフィールドにしてるのに、Expression.Propertyを使ったからエラーになって、そこでハマリましたorz
苦労した分、できたときは感動でしたw
でもGreaterThanに変更するとエラーになったりと、よくわかりません(^^;
それに可読性はすっごく悪いから、素直にSQL書いた方がよさそうですね。
私も前の記事のコメントのやり方でいきます!w

# re: ExpressionTreeを組み立てて見たいのだけど(挫折) 2007/11/23 10:33 Streetw☆

「とっても複雑なSQLにしたいときは」です>素直にSQL

# re: ExpressionTreeを組み立てて見たいのだけど(挫折) 2007/11/24 15:04 渋木宏明(ひどり)

毎回やるこっちゃないですからね>めんどくさい

こういう時こそ var の使いどころなんじゃないかな。
var をうまく使うとタイプ量が結構減ると思いますよ。

あと、場合分けでイケる場合でも、条件式を Expression の生成だけを場合分けして、クエリ実行は終端の1か所で行う方がイロイロ問題が少ないかも。

# [C#][LINQ]Expression組み立ててみよう その1 2008/04/14 21:57 かずきのBlog

[C#][LINQ]Expression組み立ててみよう その1

# sac longchamp pas cher 2012/10/19 15:51 http://www.sacslongchamppascher2013.com

Only a smiling visitor here to share the love (:, btw outstanding style and design. "Make the most of your regrets... . To regret deeply is to live afresh." by Henry David Thoreau.

# ugg online 2012/10/19 17:07 http://www.superbootonline.com

Real good information can be found on website . "The fundamental defect of fathers is that they want their children to be a credit to them." by Bertrand Russell.

# louis vuitton outlet 2012/10/28 3:58 http://www.louisvuittonoutletdiaperbag.com/

An absolute mate is a what individual overlooks your main failures and furthermore can handle your main successes.
louis vuitton outlet http://www.louisvuittonoutletdiaperbag.com/

# louis vuitton outlet 2012/10/28 4:08 http://www.louisvuittonwallets2013.com/

Do not ever look down upon, if that you are distressing, because you can't say for sure who is responsible for decreasing in love with a person's look.
louis vuitton outlet http://www.louisvuittonwallets2013.com/

# louis vuitton outlet store 2012/10/28 4:18 http://www.louisvuittonbackpack2013.com/

Since a particular person doesn‘capital t accept you how we would like them towards,doesn‘capital t lead to these folks have on‘capital t accept you with all they have perhaps.
louis vuitton outlet store http://www.louisvuittonbackpack2013.com/

# mens shirts 2012/10/28 14:37 http://www.burberryoutletonlineshopping.com/burber

I really appreciate this post. I've been looking everywhere for this! Thank goodness I found it on Bing. You've made my day! Thanks again!
mens shirts http://www.burberryoutletonlineshopping.com/burberry-men-shirts.html

# Burberry Watches 2012/10/28 14:37 http://www.burberryoutletonlineshopping.com/burber

Its good as your other posts : D, thanks for posting . "Slump I ain't in no slump... I just ain't hitting." by Yogi Berra.
Burberry Watches http://www.burberryoutletonlineshopping.com/burberry-watches.html

# burberry womens shirts 2012/10/28 14:38 http://www.burberryoutletonlineshopping.com/burber

Thankyou for helping out, superb information.
burberry womens shirts http://www.burberryoutletonlineshopping.com/burberry-womens-shirts.html

# mia clarisonic mia coupon 2012/10/30 21:38 http://www.clarisonicmia-coupon.com/

A new comrade very likely are not somebody, and yet somebody are forever a fabulous comrade.
mia clarisonic mia coupon http://www.clarisonicmia-coupon.com/

# burberry wallets 2012/10/31 20:43 http://www.burberrysalehandbags.com/burberry-walle

You are my breathing in, I possess few web logs and rarely run out from to post .
burberry wallets http://www.burberrysalehandbags.com/burberry-wallets-2012.html

# t shirt scarf 2012/10/31 21:10 http://www.burberrysalehandbags.com/burberry-scarf

I was looking at some of your posts on this website and I believe this internet site is rattling instructive! Keep putting up.
t shirt scarf http://www.burberrysalehandbags.com/burberry-scarf.html

# cheap burberry bags 2012/10/31 21:11 http://www.burberrysalehandbags.com/burberry-tote-

I dugg some of you post as I cogitated they were very helpful very helpful
cheap burberry bags http://www.burberrysalehandbags.com/burberry-tote-bags.html

# burberry womens shirts 2012/10/31 21:11 http://www.burberrysalehandbags.com/burberry-women

Merely wanna tell that this is invaluable , Thanks for taking your time to write this.
burberry womens shirts http://www.burberrysalehandbags.com/burberry-womens-shirts.html

# Burberry Ties 2012/11/02 22:57 http://www.burberrysalehandbags.com/burberry-ties.

But wanna remark on few general things, The website layout is perfect, the subject matter is really fantastic : D.
Burberry Ties http://www.burberrysalehandbags.com/burberry-ties.html

# burberry bag 2012/11/03 2:39 http://www.burberryoutletscarfsale.com/burberry-ba

I like this web blog so much, saved to fav. "Nostalgia isn't what it used to be." by Peter De Vries.
burberry bag http://www.burberryoutletscarfsale.com/burberry-bags.html

# burberry scarf 2012/11/03 2:39 http://www.burberryoutletscarfsale.com/accessories

I will right away clutch your rss as I can not to find your email subscription hyperlink or e-newsletter service. Do you've any? Kindly permit me realize so that I may subscribe. Thanks.
burberry scarf http://www.burberryoutletscarfsale.com/accessories/burberry-scarf.html

# burberry mens shirts 2012/11/03 2:39 http://www.burberryoutletscarfsale.com/burberry-me

I really like your writing style, excellent info , appreciate it for posting : D.
burberry mens shirts http://www.burberryoutletscarfsale.com/burberry-men-shirts.html

# YATLOFhfBYezq 2018/12/20 0:28 https://www.suba.me/

Pqo0Ys This particular blog is really awesome and diverting. I have picked up helluva handy things out of this blog. I ad love to visit it over and over again. Thanks!

# Hi colleagues, its impressive post concerning cultureand entirely explained, keep it up all the time. 2024/03/22 10:16 Hi colleagues, its impressive post concerning cult

Hi colleagues, its impressive post concerning cultureand entirely explained,
keep it up all the time.

# I don't even know how I ended up here, but I thought this post was great. I do not know who you are but certainly you're going to a famous blogger if you aren't already ;) Cheers! 2024/03/24 0:06 I don't even know how I ended up here, but I thoug

I don't even know how I ended up here, but I thought this post was great.

I do not know who you are but certainly you're going to
a famous blogger if you aren't already ;) Cheers!

# Thanks for finally talking about >ExpressionTreeを組み立てて見たいのだけど(挫折) <Liked it! 2024/03/25 20:48 Thanks for finally talking about >ExpressionTre

Thanks for finally talking about >ExpressionTreeを組み立てて見たいのだけど(挫折)
<Liked it!

# Hello! This post could not be written any better! Reading this post reminds me of my good old room mate! He always kept chatting about this. I will forward this write-up to him. Fairly certain he will have a good read. Thanks for sharing! 2024/03/26 7:57 Hello! This post could not be written any better!

Hello! This post could not be written any better! Reading
this post reminds me of my good old room mate!
He always kept chatting about this. I will forward this write-up to him.
Fairly certain he will have a good read. Thanks for sharing!

# I think this is among the most important info for me. And i am glad reading your article. But should remark on few general things, The web site style is ideal, the articles is really excellent : D. Good job, cheers 2024/04/02 6:50 I think this is among the most important info for

I think this is among the most important info for me.
And i am glad reading your article. But should remark on few general things, The
web site style is ideal, the articles is really excellent : D.
Good job, cheers

# Hi everyone, it's my first pay a visit at this web page, and post is really fruitful designed for me, keep up posting these types of articles. http://dseabcebyd.mee.nu/?entry=3584482 2024/04/06 6:23 Hi everyone, it's my first pay a visit at this web

Hi everyone, it's my first pay a visit at this web page,
and post is really fruitful designed for me, keep up posting these types of articles.
http://dseabcebyd.mee.nu/?entry=3584482

# Hey there! This is my 1st comment here so I just wanted to give a quick shout out and say I genuinely enjoy reading your articles. Can you recommend any other blogs/websites/forums that cover the same subjects? Many thanks! 2024/04/24 6:58 Hey there! This is my 1st comment here so I just w

Hey there! This is my 1st comment here so I just wanted to give
a quick shout out and say I genuinely enjoy reading your articles.

Can you recommend any other blogs/websites/forums
that cover the same subjects? Many thanks!

# Appreciate the recommendation. Let me try it out. 2024/04/24 7:33 Appreciate the recommendation. Let me try it out.

Appreciate the recommendation. Let me try it out.

タイトル
名前
Url
コメント