*** empty log message ***

svn path=/trunk/boinc/; revision=3332
This commit is contained in:
Rom Walton 2004-05-04 20:45:02 +00:00
parent 79250cfdc9
commit 61e6e2ffc1
2 changed files with 74 additions and 26 deletions

View File

@ -12012,3 +12012,11 @@ Rom May 4 2004
html/inc/ html/inc/
db_ops.inc db_ops.inc
Rom May 4 2004
- Use a more optimized query for the results summary page, load times go from
8-10 seconds to 1-2 seconds
- Fix client_version_num bug after field was renamed to app_version_num
html/inc/
db_ops.inc

View File

@ -190,6 +190,12 @@ function exit_status_string($result) {
} }
function show_result_summary() { function show_result_summary() {
$ntotal =0; // TODO: how to count $result?
$nvalid = 0; // for SUCCESS results
$ninvalid = 0;
$nfile_deleted = 0;
$server_state = array(); $server_state = array();
$outcome = array(); $outcome = array();
$client_state = array(); $client_state = array();
@ -207,42 +213,76 @@ function show_result_summary() {
$_GET['table'] = 'result'; $_GET['table'] = 'result';
$_GET['sort_by'] = ''; // ignore sort $_GET['sort_by'] = ''; // ignore sort
$query_appid = $_GET['appid'];
$query_received_time = time() - $_GET['nsecs'];
$q = new SqlQueryString(); $q = new SqlQueryString();
$q->process_form_items(); $q->process_form_items();
$main_query = $q->get_select_query(0,0); $main_query = "
SELECT COUNT(id) AS nTotal,
SUM(case when server_state = '1' then 1 else 0 end) AS serverstate_inactive,
SUM(case when server_state = '2' then 1 else 0 end) AS serverstate_unset,
SUM(case when server_state = '3' then 1 else 0 end) AS serverstate_unset_seq,
SUM(case when server_state = '4' then 1 else 0 end) AS serverstate_inprogress,
SUM(case when server_state = '5' then 1 else 0 end) AS serverstate_over,
SUM(case when server_state = '5' and outcome = '0' then 1 else 0 end) AS outcome_init,
SUM(case when server_state = '5' and outcome = '1' then 1 else 0 end) AS outcome_success,
SUM(case when server_state = '5' and outcome = '2' then 1 else 0 end) AS outcome_couldntsend,
SUM(case when server_state = '5' and outcome = '3' then 1 else 0 end) AS outcome_failure,
SUM(case when server_state = '5' and outcome = '4' then 1 else 0 end) AS outcome_noreply,
SUM(case when server_state = '5' and outcome = '5' then 1 else 0 end) AS outcome_didntneed,
SUM(case when server_state = '5' and outcome = '1' and validate_state = '0' then 1 else 0 end) AS validate_init,
SUM(case when server_state = '5' and outcome = '1' and validate_state = '1' then 1 else 0 end) AS validate_valid,
SUM(case when server_state = '5' and outcome = '1' and validate_state = '2' then 1 else 0 end) AS validate_invalid,
SUM(case when server_state = '5' and outcome = '1' and validate_state = '3' then 1 else 0 end) AS validate_nocheck,
SUM(case when server_state = '5' and outcome = '1' and file_delete_state = '0' then 1 else 0 end) AS filedeletestate_init,
SUM(case when server_state = '5' and outcome = '1' and file_delete_state = '1' then 1 else 0 end) AS filedeletestate_ready,
SUM(case when server_state = '5' and outcome = '1' and file_delete_state = '2' then 1 else 0 end) AS filedeletestate_done,
SUM(case when server_state = '5' and outcome = '3' and client_state = '0' then 1 else 0 end) AS clientstate_init,
SUM(case when server_state = '5' and outcome = '3' and client_state = '1' then 1 else 0 end) AS clientstate_downloading,
SUM(case when server_state = '5' and outcome = '3' and client_state = '2' then 1 else 0 end) AS clientstate_downloaded,
SUM(case when server_state = '5' and outcome = '3' and client_state = '3' then 1 else 0 end) AS clientstate_computedone,
SUM(case when server_state = '5' and outcome = '3' and client_state = '4' then 1 else 0 end) AS clientstate_uploading,
SUM(case when server_state = '5' and outcome = '3' and client_state = '5' then 1 else 0 end) AS clientstate_uploaded
FROM result
WHERE
appid='$query_appid' and
received_time > '$query_received_time';
";
$urlquery = $q->urlquery; $urlquery = $q->urlquery;
echo "<p>Query: <b>$main_query</b><p>\n";
$result = mysql_query($main_query); $result = mysql_query($main_query);
$ntotal =0; // TODO: how to count $result?
$nvalid = 0; // for SUCCESS results if ($res = mysql_fetch_object($result)) {
$ninvalid = 0; $ntotal = $res->nTotal;
$nfile_deleted = 0;
while ($res = mysql_fetch_object($result)) { $server_state[1] = $res->serverstate_inactive;
$server_state[$res->server_state] += 1; $server_state[2] = $res->serverstate_unset;
$ntotal += 1; $server_state[3] = $res->serverstate_unset_seq;
if ($res->server_state == 5) { $server_state[4] = $res->serverstate_inprogress;
$outcome[$res->outcome] += 1; $server_state[5] = $res->serverstate_over;
if ($res->outcome == 3) {
$client_state[$res->client_state] += 1; $outcome[1] = $res->outcome_success;
} $outcome[2] = $res->outcome_couldntsend;
if ($res->outcome == 1) { $outcome[3] = $res->outcome_failure;
if ($res->validate_state == 1) { $outcome[4] = $res->outcome_noreply;
$nvalid += 1; $outcome[5] = $res->outcome_didntneed;
}
if ($res->validate_state == 2) { $client_state[1] = $res->clientstate_downloading;
$ninvalid += 1; $client_state[2] = $res->clientstate_downloaded;
} $client_state[3] = $res->clientstate_computedone;
if ($res->file_delete_state >= 1) { $client_state[4] = $res->clientstate_uploading;
$nfile_deleted +=1; $client_state[5] = $res->clientstate_uploaded;
}
} $nvalid = $res->validate_valid;
} $ninvalid = $res->validate_invalid;
$nfile_deleted = $res->filedeletestate_ready + $res->filedeletestate_done;
} }
mysql_free_result($result); mysql_free_result($result);
echo "<table>"; echo "<table>";
echo "<tr valign=top>"; echo "<tr valign=top>";
echo "<td><h2>" . link_results("$ntotal results", $urlquery, '') . "</h2></td>"; echo "<td><h2>" . link_results("$ntotal results", $urlquery, '') . "</h2></td>";