# NAME Teng::Plugin::SearchBySQLAbstractMore - use [SQL::Abstract::More](https://metacpan.org/pod/SQL%3A%3AAbstract%3A%3AMore) as Query Builder for Teng # SYNOPSIS package MyApp::DB; use parent qw/Teng/; __PACKAGE__->load_plugin('SearchBySQLAbstractMore'); __PACAKGE__->sql_abstract_more_new_option(sql_dialect => 'Oracle'); # If you want to pass SQL::Abstract::More new options package main; my $db = MyApp::DB->new(dbh => $dbh); my $itr = $db->search_by_sql_abstract_more('user' => {type => 3}); my @rows = $db->search_by_sql_abstract_more('user' => {type => 3}, {rows => 5}); # use pager my $page = $c->req->param('page') || 1; my ($rows, $pager) = $db->search_by_sql_abstract_more_with_pager('user' => {type => 3}, {page => $page, rows => 5}); If you want to replace Teng search package MyApp::DB; use parent qw/Teng/; __PACKAGE__->load_plugin('SearchBySQLAbstractMore'); __PACKAGE__->install_sql_abstract_more; # now, search method is replaced by search_by_sql_abstract_more If you want to load pager at the same time # search_with_pager from SearchBySQLAbstractMore::Pager __PACKAGE__->install_sql_abstract_more(pager => 'Pager'); # search_with_pager from SearchBySQLAbstractMore::Pager::MySQLFoundRows __PACKAGE__->install_sql_abstract_more(pager => 'Pager::MySQLFoundRows'); # search_with_pager from SearchBySQLAbstractMore::Pager::Count __PACKAGE__->install_sql_abstract_more(pager => 'Pager::Count'); Create complex SQL using SQL::Abstract::More. Compatible usage with Teng's search method. $teng->search_by_sql_abstract_more ('table1', { name => { like => '%perl%'}, -and => [ {x => 1}, {y => [-or => {'>' => 2}, {'<' => 10}]}, ], }, { from => ['-join', 'table1|t1', 't1.id=t2.id', 'table2|t2', 't1.id=t3.table1_id,t2.id=t3.table2_id', 'table3|t3', ], columns => ['x', 'y', 'min(age) as min_age', 'max(age) as max_age'], group_by => ['x', 'y'], having => {'max_age' => {'<' => 10}}, }, ); # SELECT x, y, min(age) as min_age, max(age) as max_age # FROM table1 AS t1 # INNER JOIN table2 AS t2 ON ( t1.id = t2.id ) # INNER JOIN table3 AS t3 ON ( ( t1.id = t3.table1_id AND t2.id = t3.table2_id ) ) # WHERE ( ( ( x = ? AND ( y > ? OR y < ? ) ) AND name LIKE ? ) ) # GROUP BY x, y HAVING ( max_age < ? ); SQL::Abstract::More original usage(as first argument, use hash ref instead of table name): $teng->search_by_sql_abstract_more( { -columns => ['x', 'y', 'min(age) as min_age', 'max(age) as max_age'], -from => [-join, 'table1|t1', 't1.id=t2.id', 'table2|t2', 't1.id=t3.table1_id,t2.id=t3.table2_id', 'table3|t3', ], -group_by => ['x', 'y'], -having => {'max_age' => {'<' => 10'}}, -where => { name => { like => '%perl%'}, -and => [ {x => 1}, {y => [-or => {'>' => 2}, {'<' => 10}]}, ], }, }, ); # SQL is as same as the avobe code. Using pager. Compatible usage: $teng->search_by_sql_abstract_more( 'table', { name => 1, age => 10, }, { -columns => ['x', 'y'], -from => ['table'], -page => 2, -rows => 20, }, ); Originaly usage: $teng->search_by_sql_abstract_more( { -columns => ['x', 'y'], -from => ['table'], -where => { name => 1, age => 10, }, -page => 2, -rows => 20, }, ); Generate SQL by SQLAbstractMore ($sql, @binds) = $teng->create_sql_by_sql_abstract_more($table, $where, $opt); It returns SQL and bind values with same args of `search_bys_sql_abstract_more` method. # METHODS ## search\_by\_sql\_abstract\_more see SYNOPSIS. ## create\_sql\_by\_sql\_abstract\_more ($sql, @binds) = $teng->create_sql_by_sql_abstract_more($table, $where, $opt); This method returns SQL statement and its bind values. It doesn't check table is in schema. # CLASS METHOD ## sql\_abstract\_more\_instance YourClass->sql_abstract_more_instance; return SQL::Abstract::More object. ## sql\_abstract\_more\_new\_option YourClass->sql_abstract_more_new_option(sql_dialect => 'Oracle'); This method's arguments are passed to SQL::Abstract::More->new(). see [SQL::Abstract::More](https://metacpan.org/pod/SQL%3A%3AAbstract%3A%3AMore) new options. ## replace\_teng\_search If you want to replace `search` method of original Teng, call this. Teng::Plugin::SearchBySQLAbstractMore->replace_teng_search; It is useful when you wrap `search` method in your module and call Teng's `search` method in it and you want to use same usage with SQL::Abstract::More. ## install\_sql\_abstract\_more package YourClass; use Teng::Plugin::SearchBySQLAbstract::More; # no need to use ->load_plugin(); YourClass->install_sql_abstract_more; # search_sql_abstract_more is defined as YourClass::search YourClass->install_sql_abstract_more(alias => 1); # same as the above YourClass->install_sql_abstract_more(replace => 1); # Teng::Search is replaced by search_sql_abstract_more YourClass->install_sql_abstract_more(alias => 'complex_search'); # sql_abstract_more is defined as YourClass::complex_search YourClass->install_sql_abstract_more(alias => 'complex_search', pager => 1); # sql_abstract_more is defined as YourClass::complex_search # sql_abstract_more_pager is defined as YourClass::complex_search_with_pager YourClass->install_sql_abstract_more(alias => 'complex_search', pager => 1, pager_alias => 'complex_search_paged'); # sql_abstract_more is defined as YourClass::complex_search # sql_abstract_more_pager is defined as YourClass::complex_search_paged # use different pager YourClass->install_sql_abstract_more(pager => 1); # or pager => 'simple' / 'Pager' YourClass->install_sql_abstract_more(pager => 'mysql_found_rows'); # or pager => 'Pager::MySQL::FoundRows' YourClass->install_sql_abstract_more(pager => 'count'); # or pager => 'Pager::Count' It call replace\_teng\_search if replace option is passed and it is true and loads pager plugin with alias option if pager option is true. `search` and `search_with_pager` are installed to your class. This method can take the following options. ### replace If you want to replace Teng's search method, pass this option. YourClass->install_sql_abstract_more(replace => 1); ### alias YourClass->install_sql_abstract_more(alias => 'complex_search'); YourClass->install_sql_abstract_more(pager => 'Pager', alias => 'complex_search'); This is equals to: YourClass->load_plugin('Teng::Plugin::SearchBySQLAbstractMore', { alias => 'search_by_sql_abstract_more' => 'complex_search', }); YourClass->load_plugin('Teng::Plugin::SearchBySQLAbstractMore::Pager', { alias => 'search_by_sql_abstract_more_with_pager' => 'complex_search_with_pager', }); ### pager\_alias If you want to use different alias for pager search. YourClass->install_sql_abstract_more(pager => 'Pager', pager_alias => 'complex_search_with_pager'); This is equals to: YourClass->load_plugin('Teng::Plugin::SearchBySQLAbstractMore', { alias => 'search_by_sql_abstract_more' => 'search', }); YourClass->load_plugin('Teng::Plugin::SearchBySQLAbstractMore::Pager', { alias => 'search_by_sql_abstract_more_with_pager' => 'complex_search_with_pager', }); ### pager Pass pager plugin name or 1. YourClass->install_sql_abstract_more(pager => 1); # load SearchBySQLAbstractMore::Pager YourClass->install_sql_abstract_more(pager => 'Pager'); # same as the above YourClass->install_sql_abstract_more(pager => 'simple'); # same as the above YourClass->install_sql_abstract_more(pager => 'Pager::MySQLFoundRows');# load SearchBySQLAbstractMore::Pager::MySQLFoundRows YourClass->install_sql_abstract_more(pager => 'mysql_found_rows'); # same as the above YourClass->install_sql_abstract_more(pager => 'Pager::Count'); # load SearchBySQLAbstractMore::Pager::Count YourClass->install_sql_abstract_more(pager => 'count'); # same as the above # AUTHOR Ktat, `<ktat at cpan.org>` # BUGS Please report any bugs or feature requests to `bug-teng-plugin-searchbysqlabstractmore at rt.cpan.org`, or through the web interface at [http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Teng-Plugin-SearchBySQLAbstractMore](http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Teng-Plugin-SearchBySQLAbstractMore). I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. # SUPPORT You can find documentation for this module with the perldoc command. perldoc Teng::Plugin::SearchBySQLAbstractMore You can also look for information at: - RT: CPAN's request tracker [http://rt.cpan.org/NoAuth/Bugs.html?Dist=Teng-Plugin-SearchBySQLAbstractMore](http://rt.cpan.org/NoAuth/Bugs.html?Dist=Teng-Plugin-SearchBySQLAbstractMore) - AnnoCPAN: Annotated CPAN documentation [http://annocpan.org/dist/Teng-Plugin-SearchBySQLAbstractMore](http://annocpan.org/dist/Teng-Plugin-SearchBySQLAbstractMore) - CPAN Ratings [http://cpanratings.perl.org/d/Teng-Plugin-SearchBySQLAbstractMore](http://cpanratings.perl.org/d/Teng-Plugin-SearchBySQLAbstractMore) - Search CPAN [http://search.cpan.org/dist/Teng-Plugin-SearchBySQLAbstractMore/](http://search.cpan.org/dist/Teng-Plugin-SearchBySQLAbstractMore/) # SEE ALSO - [Teng](https://metacpan.org/pod/Teng) - [SQL::Abstract::More](https://metacpan.org/pod/SQL%3A%3AAbstract%3A%3AMore) # ACKNOWLEDGEMENTS # LICENSE AND COPYRIGHT Copyright 2012 Ktat. This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License. See http://dev.perl.org/licenses/ for more information.