From: Matt S Trout Date: Tue, 1 Oct 2019 17:55:10 +0000 (+0000) Subject: document group by and having clauses X-Git-Tag: v1.90_01~25 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=6aac9987ce7af38ba7ff8271a59aa68cdc9b192e;p=dbsrgits%2FSQL-Abstract.git document group by and having clauses --- diff --git a/lib/SQL/Abstract/ExtraClauses.pm b/lib/SQL/Abstract/ExtraClauses.pm index fe5af4e..e16f927 100644 --- a/lib/SQL/Abstract/ExtraClauses.pm +++ b/lib/SQL/Abstract/ExtraClauses.pm @@ -377,6 +377,11 @@ SQL::Abstract::ExtraClauses - new/experimental additions to L my $sqla = SQL::Abstract->new; SQL::Abstract::ExtraClauses->apply_to($sqla); +=head1 WARNING + +This module is basically a nursery for things that seem like a good idea +to live in until we figure out if we were right about that. + =head1 METHODS =head2 apply_to @@ -575,4 +580,44 @@ With oddities: x LEFT JOIN ( y LEFT JOIN z ) [] +=head1 STATEMENT EXTENSIONS + +=head2 group by clause for select + +Expanded as a list with an ident default: + + # expr + { -select => { group_by => [ 'foo', 'bar' ] } } + + # aqt + { -select => { group_by => + { + -op => [ ',', { -ident => [ 'foo' ] }, { -ident => [ 'bar' ] } ] + } + } } + + # query + GROUP BY foo, bar + [] + +=head2 having clause for select + +Basic expr, just like where, given having is pretty much post-group-by +where clause: + + # expr + { -select => + { having => { '>' => [ { -count => { -ident => 'foo' } }, 3 ] } } + } + + # aqt + { -select => { having => { -op => [ + '>', { -func => [ 'count', { -ident => [ 'foo' ] } ] }, + { -bind => [ undef, 3 ] }, + ] } } } + + # query + HAVING COUNT(foo) > ? + [ 3 ] + =cut