como atualizar o banco de dados após o download bem-sucedido?

Eu escrevi o script de download que irá baixar um arquivo de um diretório. Após o download bem-sucedido, preciso atualizar o banco de dados para que eu escreva o código a seguir.

<code>$path = $_SERVER['DOCUMENT_ROOT']."/upload/"; // change the path to fit your websites document structure

$fullPath = $path.$_GET['download_file'];

if ($fd = fopen ($fullPath, "r")) {
    $fsize = filesize($fullPath);
    $path_parts = pathinfo($fullPath);
    $ext = strtolower($path_parts["extension"]);
    switch ($ext) {
        case "pdf":
        header("Content-type: application/pdf"); // add here more headers for diff. extensions
        header("Content-Disposition: attachment; filename=\"".$path_parts["basename"]."\""); // use 'attachment' to force a download
        break;
        default;
        header("Content-type: application/octet-stream");
        header("Content-Disposition: filename=\"".$path_parts["basename"]."\"");
    }
    header("Content-length: $fsize");
    header("Cache-control: private"); //use this to open files directly
    while(!feof($fd)) {
        $buffer = fread($fd, 2048);
        echo $buffer;
    }
}
fclose ($fd);
$update = mysql_query("Update query");
if($update) {
echo "updated";
}
else {
echo 'error'.mysql_error();
}
exit;
</code>

Mas quando clico no link de download e aparece um pop-up de navegador no pop-up quando clico no botão cancelar, ele não deve executar a consulta de atualização, pois o arquivo não é baixado, mas quando estou usando o código acima, mesmo se eu clicar o botão cancelar a consulta de atualização executada.

Então, qual é o erro no meu código?

questionAnswers(1)

yourAnswerToTheQuestion