Bastien Koert wrote:
Few things I can think of:
1. warn the user that the query may take some time and then show a
splash type screen that indicates that something is happening
2. Run the whole thing in a new window without the toolbar
3. rework the query so it doesn't take so much time. If there are a lot
of joins in the query, you need to re-order the joins to make the
combinations more efficient, perhaps break up the queries and place the
individual results in array. Then manipulate the arrays to show the data
how you want. (I did this to great effect to get a 4 minute query down
to 10 seconds)
I just had the idea (never tried it myself) that you could possibly
fork the request process and let the child process perform the query
and the let the parent process (to which the browser 'is connected')
wait around for the child to finish ... outputting any results,
it could then be possible for user abort to be trapped in the parent
and them have some code that kills the child process (or possibly
that apache/php responds immeditately in the parent
and just lets the child keep running - or kills it off internally)
hope that makes sense. it does to me, but maybe I didn't explain it
well.
Bastien
From: <Thomas.Seiler@xxxxxxxxxxxx>
To: <php-db@xxxxxxxxxxxxx>
Subject: Long running db queries and the "STOP" button
Date: Thu, 27 Oct 2005 16:03:58 +0200
Hello list,
We are working on a project where we use PHP5 inside Apache2 and run
very long running queries on mysql 5 and postgresql. A single query
might run up to several minutes, and generally uses 100% CPU on the
database server. So far everything is fine.
Now what happens, is that sometimes the user hits the stop / back
button before the query completes and reissues a new one.
The result is that two queries are running on the database server,
even though the results of the first query will never be used.
Furthermore as both queries are concurring for the CPU, the second
query takes much longer than normal.
PHP will only realize that the connection was closed by the browser
once the database query is completed, but not during the query itself.
What we are looking for is a way to cancel a running query immediately
when the user hits the back / stop button on his browser.
We found no real solution for this problem in the usual places.
Any ideas, thoughts or comments are very welcome!
Cheers,
Thomas
---------------------------------------------
Thomas Seiler
Ing. sys. com. dipl. EPFL
SWISSCOM AG
Innovations
Security and Service Management
Ostermundigenstrasse 93
CH - 3050 Bern
SWITZERLAND
Phone: +41 (0)31 342 42 69
Mobile: +41 (0)79 427 97 26
Fax: +41 (0)31 892 62 27
Thomas.Seiler@xxxxxxxxxxxx
http://www.swisscom.com
--
PHP Database Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
--
PHP Database Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php