<?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>Alex Medina &#187; LINQ</title>
	<atom:link href="http://alexmedina.net/blog/category/linq/feed/" rel="self" type="application/rss+xml" />
	<link>http://alexmedina.net/blog</link>
	<description>Mi blog, mis cosas...</description>
	<lastBuildDate>Tue, 22 Jun 2010 08:23:03 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Linq to SQL Debug Visualizer, depura facilmente tus consultas LINQ to SQL</title>
		<link>http://alexmedina.net/blog/2009/07/01/linq-to-sql-debug-visualizer-depura-facilmente-tus-consultas-linq-to-sql/</link>
		<comments>http://alexmedina.net/blog/2009/07/01/linq-to-sql-debug-visualizer-depura-facilmente-tus-consultas-linq-to-sql/#comments</comments>
		<pubDate>Wed, 01 Jul 2009 17:18:42 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[.Net]]></category>
		<category><![CDATA[LINQ]]></category>
		<category><![CDATA[SQLServer]]></category>
		<category><![CDATA[depurar]]></category>
		<category><![CDATA[visual studio]]></category>

		<guid isPermaLink="false">http://alexmedina.net/blog/2009/07/01/linq-to-sql-debug-visualizer-depura-facilmente-tus-consultas-linq-to-sql/</guid>
		<description><![CDATA[Using the LINQ to SQL Debug Visualizer
 One of the nice development features that LINQ to SQL supports is the ability to use a &#8220;debug visualizer&#8221; to hover over a LINQ expression while in the VS 2008 debugger and inspect the raw SQL that the ORM will ultimately execute at runtime when evaluating the LINQ query [...]]]></description>
			<content:encoded><![CDATA[<h3><font face="arial" size="2"><u>Using the LINQ to SQL Debug Visualizer</u></font></h3>
<p><font face="arial" size="2"> </font><font face="arial" size="2">One of the nice development features that LINQ to SQL supports is the ability to use a &#8220;debug visualizer&#8221; to hover over a LINQ expression while in the VS 2008 debugger and inspect the raw SQL that the ORM will ultimately execute at runtime when evaluating the LINQ query expression.</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">For example, assume we write the below LINQ query expression code against a set of data model classes:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2"><img src="http://www.scottgu.com/blogposts/linqtosql3/step3.jpg" /> </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">We could then use the VS 2008 debugger to hover over the &#8220;products&#8221; variable after the query expression has been assigned:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2"><img src="http://www.scottgu.com/blogposts/linqtosql3/step4.jpg" /> </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">And if we click the small magnifying glass in the expression above, we can launch the LINQ to SQL debug visualizer to inspect the raw SQL that the ORM will execute based on that LINQ query:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2"><img src="http://www.scottgu.com/blogposts/linqtosql3/step5.jpg" /> </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">If you click the &#8220;Execute&#8221; button, you can even test out the SQL query and see the raw returned results that will be returned from the database:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2"><img src="http://www.scottgu.com/blogposts/linqtosql3/step6.jpg" /> </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">This obviously makes it super easy to see precisely what SQL query logic LINQ to SQL ORM is doing for you.  </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">You can learn even more about how all this works by reading the <a href="http://weblogs.asp.net/scottgu/archive/2007/06/29/linq-to-sql-part-3-querying-our-database.aspx" target="_blank">Part 3: Querying our Database</a> segment in my LINQ to SQL series above.</font></p>
<p><font face="arial" size="2"> </font></p>
<h3><font face="arial" size="2"><u>How to Install the LINQ to SQL Debug Visualizer</u></font></h3>
<p><font face="arial" size="2"> </font><font face="arial" size="2">The LINQ to SQL Debug Visualizer isn&#8217;t built-in to VS 2008 &#8211; instead it is an add-in that you need to download to use.  You can download a copy of it <a href="http://www.scottgu.com/blogposts/linqquery/SqlServerQueryVisualizer.zip" target="_blank">here</a>.</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">The download contains both a binary .dll assembly version of the visualizer (within the \bin\debug directory below), as well as all of the source code for the visualizer:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2"><img src="http://www.scottgu.com/blogposts/linqquery/linq1.jpg" /> </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">To install the LINQ to SQL debug visualizer, follow the below steps:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">1) Shutdown all running versions of Visual Studio 2008 </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">2) Copy the <strong>SqlServerQueryVisualizer.dll</strong> assembly from the <strong>\bin\debug\</strong> directory in the .zip download above into your local <strong>\Program Files\Microsoft Visual Studio 9.0\Common7\Packages\Debugger\Visualizers\</strong> directory:</font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2"><img src="http://www.scottgu.com/blogposts/linqquery/linq2.jpg" /> </font></p>
<p><font face="arial" size="2"> </font><font face="arial" size="2">3) Start up Visual Studio 2008 again.  Now when you use the debugger with LINQ to SQL you should be able to hover over LINQ query expressions and inspect their raw SQL (no extra registration is required).</font></p>
]]></content:encoded>
			<wfw:commentRss>http://alexmedina.net/blog/2009/07/01/linq-to-sql-debug-visualizer-depura-facilmente-tus-consultas-linq-to-sql/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Borrar registros con LINQ</title>
		<link>http://alexmedina.net/blog/2008/11/28/borrar-registros-con-linq/</link>
		<comments>http://alexmedina.net/blog/2008/11/28/borrar-registros-con-linq/#comments</comments>
		<pubDate>Fri, 28 Nov 2008 13:11:54 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[LINQ]]></category>

		<guid isPermaLink="false">http://alexmedina.net/blog/?p=25</guid>
		<description><![CDATA[' Query the database for the rows to be deleted.
Dim deleteOrderDetails = _
    From details In db.OrderDetails() _
    Where details.OrderID = 11000 _
    Select details

For Each detail As OrderDetail In deleteOrderDetails
    db.OrderDetails.DeleteOnSubmit(detail)
Next

Try
    db.SubmitChanges()
Catch ex As Exception
    Console.WriteLine(ex)
 [...]]]></description>
			<content:encoded><![CDATA[<pre class="libCScode" style="white-space: pre-wrap" id="ctl00_rs1_mainContentContainer_ctl15VisualBasic" space="preserve"><span style="color: green">' Query the database for the rows to be deleted.</span>
<span style="color: blue">Dim</span> deleteOrderDetails = _
    From details <span style="color: blue">In</span> db.OrderDetails() _
    Where details.OrderID = 11000 _
    <span style="color: blue">Select</span> details

<span style="color: blue">For</span> <span style="color: blue">Each</span> detail <span style="color: blue">As</span> OrderDetail <span style="color: blue">In</span> deleteOrderDetails
    db.OrderDetails.DeleteOnSubmit(detail)
<span style="color: blue">Next</span>

<span style="color: blue">Try</span>
    db.SubmitChanges()
<span style="color: blue">Catch</span> ex <span style="color: blue">As</span> Exception
    Console.WriteLine(ex)
    <span style="color: green">' Provide for exceptions</span>
<span style="color: blue">End</span> <span style="color: blue">Try</span></pre>
<pre class="libCScode" style="white-space: pre-wrap" id="ctl00_rs1_mainContentContainer_ctl15VisualBasic" space="preserve"></pre>
<pre class="libCScode" style="white-space: pre-wrap" id="ctl00_rs1_mainContentContainer_ctl15VisualBasic" space="preserve">Más información en  <a href="http://msdn.microsoft.com/en-us/library/bb386925.aspx">http://msdn.microsoft.com/en-us/library/bb386925.aspx</a></pre>
]]></content:encoded>
			<wfw:commentRss>http://alexmedina.net/blog/2008/11/28/borrar-registros-con-linq/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Documentación interesante para LINQ</title>
		<link>http://alexmedina.net/blog/2008/11/18/documentacion-interesante-para-linq/</link>
		<comments>http://alexmedina.net/blog/2008/11/18/documentacion-interesante-para-linq/#comments</comments>
		<pubDate>Tue, 18 Nov 2008 16:28:37 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[LINQ]]></category>

		<guid isPermaLink="false">http://alexmedina.net/blog/?p=22</guid>
		<description><![CDATA[De Microsoft:
http://msdn.microsoft.com/en-us/vcsharp/aa336746.aspx
Ejemplos de utilización en un Blog de Microsoft:
http://blogs.msdn.com/vbteam/archive/tags/Converting+SQL+to+LINQ/default.aspx
]]></description>
			<content:encoded><![CDATA[<p>De Microsoft:</p>
<p>http://msdn.microsoft.com/en-us/vcsharp/aa336746.aspx</p>
<p>Ejemplos de utilización en un Blog de Microsoft:</p>
<p>http://blogs.msdn.com/vbteam/archive/tags/Converting+SQL+to+LINQ/default.aspx</p>
]]></content:encoded>
			<wfw:commentRss>http://alexmedina.net/blog/2008/11/18/documentacion-interesante-para-linq/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Sintaxis LINQ: Any, All y Contains</title>
		<link>http://alexmedina.net/blog/2008/09/24/sintaxis-linq-any-all-y-contains/</link>
		<comments>http://alexmedina.net/blog/2008/09/24/sintaxis-linq-any-all-y-contains/#comments</comments>
		<pubDate>Wed, 24 Sep 2008 15:28:15 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[LINQ]]></category>

		<guid isPermaLink="false">http://alexmedina.net/blog/?p=19</guid>
		<description><![CDATA[Any
El operador Any se utiliza para determinar si existe un elemento dentro de una secuencia que cumpla una condición expecífica. Las signaturas del método son las siguientes:

   1:  public static bool Any&#60;TSource&#62;(
   2:      this IEnumerable&#60;TSource&#62; source)
   3:  
   4:  [...]]]></description>
			<content:encoded><![CDATA[<h2 class="pageTitle"><strong>Any</strong></h2>
<p>El operador <strong>Any</strong> se utiliza para determinar si existe un elemento dentro de una secuencia que cumpla una condición expecífica. Las signaturas del método son las siguientes:</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">public</span> <span class="kwrd">static</span> <span class="kwrd">bool</span> Any&lt;TSource&gt;(</pre>
<pre><span class="lnum">   2:  </span>    <span class="kwrd">this</span> IEnumerable&lt;TSource&gt; source)</pre>
<pre class="alt"><span class="lnum">   3:  </span></pre>
<pre><span class="lnum">   4:  </span><span class="kwrd">public</span> <span class="kwrd">static</span> <span class="kwrd">bool</span> Any&lt;TSource&gt;(</pre>
<pre class="alt"><span class="lnum">   5:  </span>    <span class="kwrd">this</span> IEnumerable&lt;TSource&gt; source,</pre>
<pre><span class="lnum">   6:  </span>    Func&lt;TSource, <span class="kwrd">bool</span>&gt; predicate)</pre>
<p>Como se puede ver en las signaturas el método devuelve <em>true</em> si algún elemento cumple con la condición y <em>false</em> si no encuentra nada. En el siguiente ejemplo queremos comprobar si existe algún desarrollador que se llame Jorge dentro de nuestra colección.</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">var</span> list = (<span class="kwrd">from</span> d <span class="kwrd">in</span> developers</pre>
<pre><span class="lnum">   2:  </span>            <span class="kwrd">select</span> d).Any(d =&gt; d.Name == <span class="str">"Jorge"</span>);</pre>
<p>El ejemplo anterior devolverá <em>true</em> ya que existe un desarrollador que se llame Jorge. Para el siguiente ejemplo, en el cual utilizamos una lista vacía, el método <strong>Any</strong> devolverá <em>false</em> ya que no existe ningún elemento en la colección.</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">var</span> list = Enumerable.Empty&lt;Developer&gt;()</pre>
<pre><span class="lnum">   2:  </span>                        .Any(d =&gt; d.Name == <span class="str">"Jorge"</span>);</pre>
<p><strong>All</strong></p>
<p>El operador <strong>All</strong> se utiliza para determinar si todos los elementos de una colección cumplen con una condición específica. La signatura del método es la siguiente:</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">public</span> <span class="kwrd">static</span> <span class="kwrd">bool</span> All&lt;TSource&gt;(</pre>
<pre><span class="lnum">   2:  </span>    <span class="kwrd">this</span> IEnumerable&lt;TSource&gt; source,</pre>
<pre class="alt"><span class="lnum">   3:  </span>    Func&lt;TSource, <span class="kwrd">bool</span>&gt; predicate)</pre>
<p>Este método devolvera <em>true</em>, si todos los elementos cumplen con la condición indicata y <em>false, si</em> hay algún elemento que no cumpla con la condición. En el siguiente ejemplo queremos comprobar que todos los desarroladores haya estado por lo menos en un cliente.</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">var</span> list = (<span class="kwrd">from</span> d <span class="kwrd">in</span> developers</pre>
<pre><span class="lnum">   2:  </span>            <span class="kwrd">select</span> d).All(d =&gt; d.Customers.Count() &gt;= 1);</pre>
<p>Si aplicamos este método sobre una colección vacía, este devolverá <em>true</em>. Esto es debido aque el método devuelve <em>false</em> encuanto encuentra un elemento que no coincide con la condición seleccionada y evidentemente en una colección vacía no va ha encontrar ningún elemento.</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">var</span> list = Enumerable.Empty&lt;Developer&gt;()</pre>
<pre><span class="lnum">   2:  </span>               .All(d =&gt; d.Customers.Count() &gt;= 1);</pre>
<p><strong>Contains</strong></p>
<p>El método <strong>Contains</strong> determina si un determinado elemento se encuentra en la colección. Las signaturas del método son las siguientes:</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span><span class="kwrd">public</span> <span class="kwrd">static</span> <span class="kwrd">bool</span> Contains&lt;TSource&gt;(</pre>
<pre><span class="lnum">   2:  </span>    <span class="kwrd">this</span> IEnumerable&lt;TSource&gt; source,</pre>
<pre class="alt"><span class="lnum">   3:  </span>    TSource <span class="kwrd">value</span>)</pre>
<pre><span class="lnum">   4:  </span></pre>
<pre class="alt"><span class="lnum">   5:  </span><span class="kwrd">public</span> <span class="kwrd">static</span> <span class="kwrd">bool</span> Contains&lt;TSource&gt;(</pre>
<pre><span class="lnum">   6:  </span>    <span class="kwrd">this</span> IEnumerable&lt;TSource&gt; source,</pre>
<pre class="alt"><span class="lnum">   7:  </span>    TSource <span class="kwrd">value</span>,</pre>
<pre><span class="lnum">   8:  </span>    IEqualityComparer&lt;TSource&gt; comparer)</pre>
<p>En la segunda signatura nos permite personalidar la forma en la que las comparaciones son realizas. Este método devolverá <em>true</em> si en cuentra el elemento y <em>false </em>sino existe el elemento en la colección.</p>
<p>En el siguiente ejemplo, queremos comprobar que en la colección exista el desarrollador, Jorge. Como veréis en el código ,hemos aprovechado la segunda signatura de este método para que se busque por el nombre simplemente.</p>
<p class="csharpcode">
<pre class="alt"><span class="lnum">   1:  </span>Developer d = <span class="kwrd">new</span> Developer{ Name=<span class="str">"Jorge"</span>, Language=<span class="str">"C#"</span>, Age=18};</pre>
<pre><span class="lnum">   2:  </span></pre>
<pre class="alt"><span class="lnum">   3:  </span><span class="kwrd">var</span> list = developers.Contains(d, <span class="kwrd">new</span> DeveloperComparer());</pre>
<pre><span class="lnum">   4:  </span></pre>
<pre class="alt"><span class="lnum">   5:  </span><span class="kwrd">public</span> <span class="kwrd">class</span> DeveloperComparer : IEqualityComparer&lt;Developer&gt;</pre>
<pre><span class="lnum">   6:  </span>{</pre>
<pre class="alt"><span class="lnum">   7:  </span>    <span class="kwrd">public</span> <span class="kwrd">bool</span> Equals(Developer x, Developer y)</pre>
<pre><span class="lnum">   8:  </span>    {</pre>
<pre class="alt"><span class="lnum">   9:  </span>        <span class="kwrd">if</span> (x.Name == y.Name)</pre>
<pre><span class="lnum">  10:  </span>        {</pre>
<pre class="alt"><span class="lnum">  11:  </span>            <span class="kwrd">return</span> <span class="kwrd">true</span>;</pre>
<pre><span class="lnum">  12:  </span>        }</pre>
<pre class="alt"><span class="lnum">  13:  </span></pre>
<pre><span class="lnum">  14:  </span>        <span class="kwrd">return</span> <span class="kwrd">false</span>;</pre>
<pre class="alt"><span class="lnum">  15:  </span>    }</pre>
<pre><span class="lnum">  16:  </span></pre>
<pre class="alt"><span class="lnum">  17:  </span>    <span class="kwrd">public</span> <span class="kwrd">int</span> GetHashCode(Developer obj)</pre>
<pre><span class="lnum">  18:  </span>    {</pre>
<pre class="alt"><span class="lnum">  19:  </span>        <span class="kwrd">return</span> obj.Name.ToString().GetHashCode();</pre>
<pre><span class="lnum">  20:  </span>    }</pre>
<pre class="alt"><span class="lnum">  21:  </span>}</pre>
]]></content:encoded>
			<wfw:commentRss>http://alexmedina.net/blog/2008/09/24/sintaxis-linq-any-all-y-contains/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
