<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Florent Clairambault &#187; SQL</title>
	<atom:link href="http://florent.clairambault.fr/tag/sql/feed" rel="self" type="application/rss+xml" />
	<link>http://florent.clairambault.fr</link>
	<description></description>
	<lastBuildDate>Sat, 04 Feb 2012 19:56:37 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.4-alpha-19719</generator>
		<item>
		<title>LinQ : Join with multiple conditions</title>
		<link>http://florent.clairambault.fr/linq-join-with-multiple-conditions?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=linq-join-with-multiple-conditions</link>
		<comments>http://florent.clairambault.fr/linq-join-with-multiple-conditions#comments</comments>
		<pubDate>Thu, 22 Oct 2009 21:30:28 +0000</pubDate>
		<dc:creator>Florent Clairambault</dc:creator>
				<category><![CDATA[English]]></category>
		<category><![CDATA[LinQ]]></category>
		<category><![CDATA[SQL]]></category>

		<guid isPermaLink="false">http://florent.clairambault.fr/?p=1842</guid>
		<description><![CDATA[I wanted to some simple join in LinQ on multiple criteria. And coming from standard SQL it&#8217;s not as straightforward as I thought it would be. The little disturbing thing is that you lose auto-completion. Here is my database schema : 1 2 3 4 5 6 7 8 9 10 11 12 13 User: [...]]]></description>
			<content:encoded><![CDATA[<p>I wanted to some simple join in LinQ on multiple criteria. And coming from standard SQL it&#8217;s not as straightforward as I thought it would be. The little disturbing thing is that you lose auto-completion.</p>
<p>Here is my database schema :</p>

<div class="wp_codebox"><table><tr id="p18424"><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
</pre></td><td class="code" id="p1842code4"><pre class="txt" style="font-family:monospace;">User:
* UserId          int           (PK)
* Login           String
* DateOfBirth     DateTime
&nbsp;
Parameter:
* ParameterId     int           (PK)
* Name            String
&nbsp;
User_Parameter:
* UserId          int           (FK User:Userid)
* ParameterId     int           (FK Parameter:ParameterId)
* Value           String</pre></td></tr></table></div>

<p>If you want to fetch the &#8220;PreferredSuperHero&#8221; parameter, you have to execute :</p>

<div class="wp_codebox"><table><tr id="p18425"><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
</pre></td><td class="code" id="p1842code5"><pre class="sql" style="font-family:monospace;">var query <span style="color: #66cc66;">=</span> 
<span style="color: #993333; font-weight: bold;">from</span> user <span style="color: #993333; font-weight: bold;">in</span> Db<span style="color: #66cc66;">.</span>User
<span style="color: #993333; font-weight: bold;">join</span> preferredSuperHero <span style="color: #993333; font-weight: bold;">in</span> Db<span style="color: #66cc66;">.</span>User_Parameter <span style="color: #993333; font-weight: bold;">on</span> 
	new <span style="color: #66cc66;">&#123;</span> 
		UserId <span style="color: #66cc66;">=</span> user<span style="color: #66cc66;">.</span>UserId<span style="color: #66cc66;">,</span> 
		ParamName <span style="color: #66cc66;">=</span> <span style="color: #ff0000;">&quot;PreferredSuperHero&quot;</span> 
	<span style="color: #66cc66;">&#125;</span> 
	equals new <span style="color: #66cc66;">&#123;</span> 
		UserId  <span style="color: #66cc66;">=</span> preferredSuperHero<span style="color: #66cc66;">.</span>UderId<span style="color: #66cc66;">,</span> 
		ParamName <span style="color: #66cc66;">=</span> preferredSuperHero<span style="color: #66cc66;">.</span>Parameter<span style="color: #66cc66;">.</span>Name 
	<span style="color: #66cc66;">&#125;</span>
orderby user<span style="color: #66cc66;">.</span>Name
<span style="color: #993333; font-weight: bold;">select</span> new <span style="color: #66cc66;">&#123;</span> User <span style="color: #66cc66;">=</span> user<span style="color: #66cc66;">,</span> PreferredSuperHero <span style="color: #66cc66;">=</span> preferredSuperHero <span style="color: #66cc66;">&#125;</span>;</pre></td></tr></table></div>

<p>In SQL, you would execute :</p>

<div class="wp_codebox"><table><tr id="p18426"><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code" id="p1842code6"><pre class="sql" style="font-family:monospace;"><span style="color: #993333; font-weight: bold;">SELECT</span> <span style="color: #ff0000;">`u`</span><span style="color: #66cc66;">.*,</span> <span style="color: #ff0000;">`up`</span><span style="color: #66cc66;">.*</span>
<span style="color: #993333; font-weight: bold;">FROM</span> <span style="color: #ff0000;">`user`</span> <span style="color: #993333; font-weight: bold;">AS</span> <span style="color: #ff0000;">`u`</span>
<span style="color: #993333; font-weight: bold;">JOIN</span> <span style="color: #ff0000;">`Parameter`</span> <span style="color: #993333; font-weight: bold;">AS</span> <span style="color: #ff0000;">`p`</span>
<span style="color: #993333; font-weight: bold;">JOIN</span> <span style="color: #ff0000;">`User_Parameter`</span> <span style="color: #993333; font-weight: bold;">AS</span> <span style="color: #ff0000;">`up`</span> <span style="color: #993333; font-weight: bold;">ON</span> <span style="color: #ff0000;">`up`</span><span style="color: #66cc66;">.</span><span style="color: #ff0000;">`UserId`</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">`u`</span><span style="color: #66cc66;">.</span><span style="color: #ff0000;">`UserId`</span> <span style="color: #993333; font-weight: bold;">AND</span> <span style="color: #ff0000;">`up`</span><span style="color: #66cc66;">.</span><span style="color: #ff0000;">`ParameterId`</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">`p`</span><span style="color: #66cc66;">.</span><span style="color: #ff0000;">`ParameterId`</span>
<span style="color: #993333; font-weight: bold;">WHERE</span>  <span style="color: #ff0000;">`p`</span><span style="color: #66cc66;">.</span><span style="color: #ff0000;">`ParamName`</span><span style="color: #66cc66;">=</span><span style="color: #ff0000;">'PreferredSuperHero'</span></pre></td></tr></table></div>

<p>On the LinQ Query, the creation of an anonymous type is necessary for the multiple join condition you can see on line 4.</p>
]]></content:encoded>
			<wfw:commentRss>http://florent.clairambault.fr/linq-join-with-multiple-conditions/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

<!-- Performance optimized by W3 Total Cache. Learn more: http://www.w3-edge.com/wordpress-plugins/

Minified using disk: basic
Page Caching using disk: enhanced
Database Caching 1/12 queries in 0.004 seconds using disk: basic
Object Caching 434/443 objects using disk: basic

Served from: florent.clairambault.fr @ 2012-02-07 10:13:39 -->
