diff options
| author | ivan <ivan> | 2002-07-07 11:03:08 +0000 | 
|---|---|---|
| committer | ivan <ivan> | 2002-07-07 11:03:08 +0000 | 
| commit | 73233cfa60984978f1593bf86c248c0bab3620a5 (patch) | |
| tree | c699be6c962ab5ce9cb76a0d8d6cd7b87db0a8dc | |
| parent | 0b8f79a88503618bca0e18d02aeebdbb1e3b47ba (diff) | |
move query logic from perl to sql for scalability
| -rwxr-xr-x | httemplate/search/cust_bill.cgi | 65 | 
1 files changed, 52 insertions, 13 deletions
| diff --git a/httemplate/search/cust_bill.cgi b/httemplate/search/cust_bill.cgi index d83851804..dbe7e7dcd 100755 --- a/httemplate/search/cust_bill.cgi +++ b/httemplate/search/cust_bill.cgi @@ -1,44 +1,83 @@  <% +my $conf = new FS::Conf; +my $maxrecords = $conf->config('maxsearchrecordsperpage'); + +my $orderby = ''; #removeme + +my $limit = ''; +$limit .= "LIMIT $maxrecords" if $maxrecords; + +my $offset = $cgi->param('offset') || 0; +$limit .= " OFFSET $offset" if $offset; + +my $total; +  my(@cust_bill, $sortby);  if ( $cgi->keywords ) {    my($query) = $cgi->keywords; +  my $open_sql = +    "having 0 != charged - coalesce(sum(cust_bill_pay.amount),0) +                         - coalesce(sum(cust_credit_bill.amount),0)"; +  my $having = ''; +  my $where = '';    if ( $query eq 'invnum' ) {      $sortby = \*invnum_sort; -    @cust_bill = qsearch('cust_bill', {} ); +    #@cust_bill = qsearch('cust_bill', {} );    } elsif ( $query eq 'date' ) {      $sortby = \*date_sort; -    @cust_bill = qsearch('cust_bill', {} ); +    #@cust_bill = qsearch('cust_bill', {} );    } elsif ( $query eq 'custnum' ) {      $sortby = \*custnum_sort; -    @cust_bill = qsearch('cust_bill', {} ); +    #@cust_bill = qsearch('cust_bill', {} );    } elsif ( $query eq 'OPEN_invnum' ) {      $sortby = \*invnum_sort; -    @cust_bill = grep $_->owed != 0, qsearch('cust_bill', {} ); +    #@cust_bill = grep $_->owed != 0, qsearch('cust_bill', {} ); +    $having = $open_sql;    } elsif ( $query eq 'OPEN_date' ) {      $sortby = \*date_sort; -    @cust_bill = grep $_->owed != 0, qsearch('cust_bill', {} ); +    #@cust_bill = grep $_->owed != 0, qsearch('cust_bill', {} ); +    $having = $open_sql;    } elsif ( $query eq 'OPEN_custnum' ) {      $sortby = \*custnum_sort; -    @cust_bill = grep $_->owed != 0, qsearch('cust_bill', {} ); +    #@cust_bill = grep $_->owed != 0, qsearch('cust_bill', {} ); +    $having = $open_sql;    } elsif ( $query =~ /^OPEN(\d+)_invnum$/ ) {      my $open = $1 * 86400;      $sortby = \*invnum_sort; -    @cust_bill = -      grep $_->owed != 0 && $_->_date < time - $open, qsearch('cust_bill', {} ); +    #@cust_bill = +    #  grep $_->owed != 0 && $_->_date < time - $open, qsearch('cust_bill', {} ); +    $having = $open_sql; +    $where = "where cust_bill._date < ". (time-$open);    } elsif ( $query =~ /^OPEN(\d+)_date$/ ) {      my $open = $1 * 86400;      $sortby = \*date_sort; -    @cust_bill = -      grep $_->owed != 0 && $_->_date < time - $open, qsearch('cust_bill', {} ); +    #@cust_bill = +    #  grep $_->owed != 0 && $_->_date < time - $open, qsearch('cust_bill', {} ); +    $having = $open_sql; +    $where = "where cust_bill._date < ". (time-$open);    } elsif ( $query =~ /^OPEN(\d+)_custnum$/ ) {      my $open = $1 * 86400;      $sortby = \*custnum_sort; -    @cust_bill = -      grep $_->owed != 0 && $_->_date < time - $open, qsearch('cust_bill', {} ); +    #@cust_bill = +    #  grep $_->owed != 0 && $_->_date < time - $open, qsearch('cust_bill', {} ); +    $having = $open_sql; +    $where = "where cust_bill._date < ". (time-$open);    } else {      die "unknown query string $query";    } +  @cust_bill = qsearch( +    'cust_bill', +    {}, +    'cust_bill.*, +     charged - coalesce(sum(cust_bill_pay.amount),0) +              - coalesce(sum(cust_credit_bill.amount),0) as owed', +    "left outer join cust_bill_pay using ( invnum ) +     left outer join cust_credit_bill using ( invnum ) +     $where +     group by ". join(', ', map "cust_bill.$_", fields('cust_bill') ). ' '. +     $having +  );  } else {    $cgi->param('invnum') =~ /^\s*(FS-)?(\d+)\s*$/;    my $invnum = $2; @@ -58,7 +97,7 @@ if ( scalar(@cust_bill) == 1 ) {  %>  <!-- mason kludge -->  <% -  my $total = scalar(@cust_bill); +  $total = scalar(@cust_bill);    print header("Invoice Search Results", menubar(            'Main Menu', popurl(2)          )), "$total matching invoices found<BR>", &table(), <<END; | 
