IWETHEY v. 0.3.0 | TODO
1,095 registered users | 0 active users | 0 LpH | Statistics
Login | Create New User
IWETHEY Banner

Welcome to IWETHEY!

New After some MySQL clues.
I've got a query that seems to fall off a performance cliff. It does a fairly simple SELECT on a single table used for logging with a WHERE clause to limit the date range. If the query looks for a month of data, it takes about 7 minutes to run. If I ask for half-a-month, it takes 12 seconds. :-/ Yes, it's using the index on the datestamp field.

I started looking at server variables, wondering if the dataset is large enough that it crosses some sort of threshold that changes behaviour and thus the slowdown. I've doubled the sort_buffer, the read buffer, to no effect. I increased the maximum in-memory/temporary table size. Also no effect. Note I cannot restart the database: all changes must be done with SET GLOBAL var=value;

Anyone have any other ideas?

Wade.


Is it enough to love
Is it enough to breathe
Somebody rip my heart out
And leave me here to bleed
 
Is it enough to die
Somebody save my life
I'd rather be Anything but Ordinary
Please



-- "Anything but Ordinary" by Avril Lavigne.

· my ·
· [link|http://staticsan.livejournal.com/|blog] ·
· [link|http://yceran.org/|website] ·

New What I'd do
Start at the half-month criteria. Increase one day at a time until the performance tanks. Then (assuming you've been keeping the start date and moving the end date closer to NOW) back up both the start and end dates. See if it's the number of days, or that specific day that's causing problems.
===

Kip Hawley is still an idiot.

===

Purveyor of Doc Hope's [link|http://DocHope.com|fresh-baked dog biscuits and pet treats].
[link|http://DocHope.com|http://DocHope.com]
New I approached that from another direction.
The original query, actually generated by code I wrote being invoked by an end-user, was for a whole month. I fished the query out of the debugging.

I already knew a smaller time-frame affects this query. So I doubted it was data-based. But I did the sort of test you described: I ran it for the first half of the month: 7 seconds. Then I altered the dates for the second half of the month: 7 seconds. :-/ It's obviously the number of days. I can find the break point without too much more effort, but I don't think knowing that will win me anything.

Wade.


Is it enough to love
Is it enough to breathe
Somebody rip my heart out
And leave me here to bleed
 
Is it enough to die
Somebody save my life
I'd rather be Anything but Ordinary
Please



-- "Anything but Ordinary" by Avril Lavigne.

· my ·
· [link|http://staticsan.livejournal.com/|blog] ·
· [link|http://yceran.org/|website] ·

New Re: I approached that from another direction.
EXPLAIN is your friend in weird cases like this. If you find that MySQL, for reasons obscure, has decided to do a full table scan, you can use a FORCE INDEX hint to set things right (for MySQL 5.0+, at least).

[link|http://dev.mysql.com/doc/refman/5.0/en/index-hints.html|http://dev.mysql.com.../index-hints.html] for details.
New FORCE INDEX is new to me.
I had been using EXPLAIN. And USE INDEX. With it without USE INDEX, a month or half-a-month, it still uses the correct index. I'll try FORCE INDEX, though.

Wade.


Is it enough to love
Is it enough to breathe
Somebody rip my heart out
And leave me here to bleed
 
Is it enough to die
Somebody save my life
I'd rather be Anything but Ordinary
Please



-- "Anything but Ordinary" by Avril Lavigne.

· my ·
· [link|http://staticsan.livejournal.com/|blog] ·
· [link|http://yceran.org/|website] ·

     After some MySQL clues. - (static) - (4)
         What I'd do - (drewk) - (3)
             I approached that from another direction. - (static) - (2)
                 Re: I approached that from another direction. - (dws) - (1)
                     FORCE INDEX is new to me. - (static)

My head feels like a frisbee.
112 ms