<?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>Ivan Villareal</title>
	<atom:link href="http://blog.ivanvillareal.info/tag/sql/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.ivanvillareal.info</link>
	<description>IT stuff and more...</description>
	<lastBuildDate>Fri, 13 Aug 2010 23:05:31 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Getting first and last row from a group set without sub queries in mysql</title>
		<link>http://blog.ivanvillareal.info/development/mysql-development/getting-first-and-last-row-from-a-group-set-without-sub-queries-in-mysql/</link>
		<comments>http://blog.ivanvillareal.info/development/mysql-development/getting-first-and-last-row-from-a-group-set-without-sub-queries-in-mysql/#comments</comments>
		<pubDate>Fri, 19 Feb 2010 01:45:24 +0000</pubDate>
		<dc:creator>Ivan Villareal</dc:creator>
				<category><![CDATA[Mysql]]></category>
		<category><![CDATA[db]]></category>
		<category><![CDATA[group]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[sql]]></category>
		<category><![CDATA[tips]]></category>

		<guid isPermaLink="false">http://blog.ivanvillareal.info/?p=206</guid>
		<description><![CDATA[How I use group_concat to get the last row from a GROUP_BY clause]]></description>
			<content:encoded><![CDATA[<p>When I use the GROUP BY clause in mysql It starts grouping by the first different row in the resultset so for example if I have this table:</p>
<p>&nbsp;</p>
<p><!--DEVFMTCODE--><pre class="devcodeblock" title="MySQL"><div class="devcodeoverflow">mysql<span style="color: #CC0099;">&gt;</span> <span style="color: #990099; font-weight: bold;">select</span> <span style="color: #CC0099;">*</span> <span style="color: #990099; font-weight: bold;">from</span> grouptest<span style="color: #000033;">;</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span> id <span style="color: #CC0099;">|</span> city    <span style="color: #CC0099;">|</span> <span style="color: #990099; font-weight: bold;">value</span> <span style="color: #CC0099;">|</span> <span style="color: #999900; font-weight: bold;">date</span>       <span style="color: #CC0099;">|</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span>  1 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>02 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  2 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    11 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>09 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  3 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    15 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>12 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  4 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    17 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  5 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    12 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>10 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  6 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>     1 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>14 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  7 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    29 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
7 rows <span style="color: #990099; font-weight: bold;">in</span> <span style="color: #990099; font-weight: bold;">set</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #008080;">0.00</span> sec<span style="color: #FF00FF;">&#41;</span></div></pre><!--END_DEVFMTCODE--></p>
<p>&nbsp;</p>
<p>If I group by city this is what I get:</p>
<p><!--DEVFMTCODE--><pre class="devcodeblock" title="MySQL"><div class="devcodeoverflow">mysql<span style="color: #CC0099;">&gt;</span> <span style="color: #990099; font-weight: bold;">SELECT</span> <span style="color: #CC0099;">*</span> <span style="color: #990099; font-weight: bold;">FROM</span> grouptest g <span style="color: #990099; font-weight: bold;">GROUP BY</span> city<span style="color: #000033;">;</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span> id <span style="color: #CC0099;">|</span> city    <span style="color: #CC0099;">|</span> <span style="color: #990099; font-weight: bold;">value</span> <span style="color: #CC0099;">|</span> <span style="color: #999900; font-weight: bold;">date</span>       <span style="color: #CC0099;">|</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span>  5 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    12 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>10 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  1 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>02 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
2 rows <span style="color: #990099; font-weight: bold;">in</span> <span style="color: #990099; font-weight: bold;">set</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #008080;">0.00</span> sec<span style="color: #FF00FF;">&#41;</span></div></pre><!--END_DEVFMTCODE--></p>
<p>&nbsp;</p>
<p>But I want to get the last inserted rows, so could do a sub query like this:</p>
<p><!--DEVFMTCODE--><pre class="devcodeblock" title="MySQL"><div class="devcodeoverflow">mysql<span style="color: #CC0099;">&gt;</span> <span style="color: #990099; font-weight: bold;">SELECT</span> <span style="color: #CC0099;">*</span> <span style="color: #990099; font-weight: bold;">FROM</span> grouptest g
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">WHERE</span> g.<span style="color: #999900; font-weight: bold;">date</span> <span style="color: #CC0099;">=</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #990099; font-weight: bold;">SELECT</span> <span style="color: #000099;">MAX</span><span style="color: #FF00FF;">&#40;</span><span style="color: #999900; font-weight: bold;">date</span><span style="color: #FF00FF;">&#41;</span> <span style="color: #990099; font-weight: bold;">FROM</span> grouptest gt <span style="color: #990099; font-weight: bold;">WHERE</span> g.city <span style="color: #CC0099;">=</span> gt.city<span style="color: #FF00FF;">&#41;</span>
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">GROUP BY</span> g.city<span style="color: #000033;">;</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span> id <span style="color: #CC0099;">|</span> city    <span style="color: #CC0099;">|</span> <span style="color: #990099; font-weight: bold;">value</span> <span style="color: #CC0099;">|</span> <span style="color: #999900; font-weight: bold;">date</span>       <span style="color: #CC0099;">|</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span>  7 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    29 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  4 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    17 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
2 rows <span style="color: #990099; font-weight: bold;">in</span> <span style="color: #990099; font-weight: bold;">set</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #008080;">0.00</span> sec<span style="color: #FF00FF;">&#41;</span></div></pre><!--END_DEVFMTCODE--></p>
<p>&nbsp;</p>
<p>But if the db is large making subqueries could be expensive, so a cleaner solution might be using the <a href="http://dev.mysql.com/doc/refman/5.0/en/group-by-functions.html#function_group-concat" target="_blank">GROUP_CONCAT</a> function, so for example the above query could be written like this:</p>
<p><!--DEVFMTCODE--><pre class="devcodeblock" title="MySQL"><div class="devcodeoverflow">mysql<span style="color: #CC0099;">&gt;</span> <span style="color: #990099; font-weight: bold;">SELECT</span> id<span style="color: #000033;">,</span> city<span style="color: #000033;">,</span> <span style="color: #990099; font-weight: bold;">value</span><span style="color: #000033;">,</span> <span style="color: #999900; font-weight: bold;">date</span><span style="color: #000033;">,</span> <span style="color: #000099;">GROUP_CONCAT</span><span style="color: #FF00FF;">&#40;</span><span style="color: #999900; font-weight: bold;">date</span><span style="color: #FF00FF;">&#41;</span> <span style="color: #990099; font-weight: bold;">AS</span> all_dates
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">FROM</span> grouptest g
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">GROUP BY</span> city<span style="color: #000033;">;</span>
<span style="color: #CC0099;">+----+---------+-------+------------+---------------------------------------------+</span>
<span style="color: #CC0099;">|</span> id <span style="color: #CC0099;">|</span> city    <span style="color: #CC0099;">|</span> <span style="color: #990099; font-weight: bold;">value</span> <span style="color: #CC0099;">|</span> <span style="color: #999900; font-weight: bold;">date</span>       <span style="color: #CC0099;">|</span> all_dates                                   <span style="color: #CC0099;">|</span>
<span style="color: #CC0099;">+----+---------+-------+------------+---------------------------------------------+</span>
<span style="color: #CC0099;">|</span>  5 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    12 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>10<span style="color: #000033;">,</span>2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>14<span style="color: #000033;">,</span>2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17            <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  1 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>02 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>02<span style="color: #000033;">,</span>2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>09<span style="color: #000033;">,</span>2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>12<span style="color: #000033;">,</span>2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">+----+---------+-------+------------+---------------------------------------------+</span>
2 rows <span style="color: #990099; font-weight: bold;">in</span> <span style="color: #990099; font-weight: bold;">set</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #008080;">0.00</span> sec<span style="color: #FF00FF;">&#41;</span></div></pre><!--END_DEVFMTCODE--><br />
&nbsp;<br />
At this point I can explode the all_dates column in php or split them in perl to get the last date for each city, but a little more work on our query could do our job simpler, something like this for instance:</p>
<p><!--DEVFMTCODE--><pre class="devcodeblock" title="MySQL"><div class="devcodeoverflow">mysql<span style="color: #CC0099;">&gt;</span> <span style="color: #990099; font-weight: bold;">SELECT</span> id<span style="color: #000033;">,</span> city<span style="color: #000033;">,</span> <span style="color: #990099; font-weight: bold;">value</span><span style="color: #000033;">,</span> <span style="color: #000099;">SUBSTRING_INDEX</span><span style="color: #FF00FF;">&#40;</span><span style="color: #000099;">GROUP_CONCAT</span><span style="color: #FF00FF;">&#40;</span><span style="color: #999900; font-weight: bold;">date</span><span style="color: #FF00FF;">&#41;</span><span style="color: #000033;">,</span><span style="color: #008000;">','</span><span style="color: #000033;">,</span><span style="color: #CC0099;">-</span>1<span style="color: #FF00FF;">&#41;</span> <span style="color: #990099; font-weight: bold;">AS</span> <span style="color: #999900; font-weight: bold;">date</span>
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">FROM</span> grouptest g
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">GROUP BY</span> city<span style="color: #000033;">;</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span> id <span style="color: #CC0099;">|</span> city    <span style="color: #CC0099;">|</span> <span style="color: #990099; font-weight: bold;">value</span> <span style="color: #CC0099;">|</span> <span style="color: #999900; font-weight: bold;">date</span>       <span style="color: #CC0099;">|</span>
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
<span style="color: #CC0099;">|</span>  5 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    12 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  1 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">+----+---------+-------+------------+</span>
2 rows <span style="color: #990099; font-weight: bold;">in</span> <span style="color: #990099; font-weight: bold;">set</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #008080;">0.00</span> sec<span style="color: #FF00FF;">&#41;</span>
</div></pre><!--END_DEVFMTCODE--><br />
&nbsp;<br />
Or if I need to get the first and last rows for each group set I just add the date column like this:</p>
<p><!--DEVFMTCODE--><pre class="devcodeblock" title="MySQL"><div class="devcodeoverflow">mysql<span style="color: #CC0099;">&gt;</span> <span style="color: #990099; font-weight: bold;">SELECT</span> id<span style="color: #000033;">,</span> city<span style="color: #000033;">,</span> <span style="color: #990099; font-weight: bold;">value</span><span style="color: #000033;">,</span> <span style="color: #999900; font-weight: bold;">date</span> <span style="color: #990099; font-weight: bold;">as</span> first_date<span style="color: #000033;">,</span> <span style="color: #000099;">SUBSTRING_INDEX</span><span style="color: #FF00FF;">&#40;</span><span style="color: #000099;">GROUP_CONCAT</span><span style="color: #FF00FF;">&#40;</span><span style="color: #999900; font-weight: bold;">date</span><span style="color: #FF00FF;">&#41;</span><span style="color: #000033;">,</span><span style="color: #008000;">','</span><span style="color: #000033;">,</span><span style="color: #CC0099;">-</span>1<span style="color: #FF00FF;">&#41;</span> <span style="color: #990099; font-weight: bold;">AS</span> last_date
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">FROM</span> grouptest g
    <span style="color: #CC0099;">-&gt;</span> <span style="color: #990099; font-weight: bold;">GROUP BY</span> city<span style="color: #000033;">;</span>
<span style="color: #CC0099;">+----+---------+-------+------------+------------+</span>
<span style="color: #CC0099;">|</span> id <span style="color: #CC0099;">|</span> city    <span style="color: #CC0099;">|</span> <span style="color: #990099; font-weight: bold;">value</span> <span style="color: #CC0099;">|</span> first_date <span style="color: #CC0099;">|</span> last_date  <span style="color: #CC0099;">|</span>
<span style="color: #CC0099;">+----+---------+-------+------------+------------+</span>
<span style="color: #CC0099;">|</span>  5 <span style="color: #CC0099;">|</span> tecate  <span style="color: #CC0099;">|</span>    12 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">|</span>  1 <span style="color: #CC0099;">|</span> tijuana <span style="color: #CC0099;">|</span>    10 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>02 <span style="color: #CC0099;">|</span> 2010<span style="color: #CC0099;">-</span>02<span style="color: #CC0099;">-</span>17 <span style="color: #CC0099;">|</span> 
<span style="color: #CC0099;">+----+---------+-------+------------+------------+</span>
2 rows <span style="color: #990099; font-weight: bold;">in</span> <span style="color: #990099; font-weight: bold;">set</span> <span style="color: #FF00FF;">&#40;</span><span style="color: #008080;">0.00</span> sec<span style="color: #FF00FF;">&#41;</span>
</div></pre><!--END_DEVFMTCODE--></p>
<p>&nbsp;</p>
<p>There may be several other ways around this, but for now this approach is enough, I’m not sure about the impact this 2 functions may have on the server but I’m sure it is less than executing a subquery.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.ivanvillareal.info/development/mysql-development/getting-first-and-last-row-from-a-group-set-without-sub-queries-in-mysql/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

<!-- www.000webhost.com Analytics Code -->
<script type="text/javascript" src="http://analytics.hosting24.com/count.php"></script>
<noscript><a href="http://www.hosting24.com/"><img src="http://analytics.hosting24.com/count.php" alt="web hosting" /></a></noscript>
<!-- End Of Analytics Code -->
