The Arcive of Official vBulletin Modifications Site.It is not a VB3 engine, just a parsed copy! |
|
#1
|
||||
|
||||
"ORDER BY" without large table scans and filesort
OK, this seems to be impossible but I thought I could ask anyway, maybe I overlooked smth. and somebody has the 1.000.000 $ answer
Let's say I got a table with several tenthousand records; the primary index as an auto-increment integer. Now I want the last record. I could do [sql]SELECT * FROM table ORDER BY id DESC LIMIT 1[/sql] But this causes large table scans ... |
#2
|
|||
|
|||
Primary index should be an unique index, and not cause full table scans.
Try playing with a HAVING max(id). |
#3
|
||||
|
||||
Hmm ...
[sql]EXPLAIN SELECT * FROM thread ORDER BY threadid DESC LIMIT 1[/sql] Code:
id select_type table type possible_keys key key_len ref rows Extra 1 SIMPLE thread ALL NULL NULL NULL NULL 32 Any ideas? |
#4
|
|||
|
|||
Well this seems like there is no index on threadid. Try creating another unique ascending index on threadid.
|
#5
|
||||
|
||||
Erm ... threadid is the PRIMARY index of table thread
Although it IMHO doesn't make sense to add another index to the column, i did so - no change. Schema [sql] CREATE TABLE thread ( threadid int(10) unsigned NOT NULL auto_increment, title varchar(250) NOT NULL default '', firstpostid int(10) unsigned NOT NULL default '0', lastpost int(10) unsigned NOT NULL default '0', forumid smallint(5) unsigned NOT NULL default '0', pollid int(10) unsigned NOT NULL default '0', `open` smallint(6) NOT NULL default '0', replycount int(10) unsigned NOT NULL default '0', postusername varchar(100) NOT NULL default '', postuserid int(10) unsigned NOT NULL default '0', lastposter varchar(50) NOT NULL default '', dateline int(10) unsigned NOT NULL default '0', views int(10) unsigned NOT NULL default '0', iconid smallint(5) unsigned NOT NULL default '0', notes varchar(250) NOT NULL default '', visible smallint(6) NOT NULL default '0', sticky smallint(6) NOT NULL default '0', votenum smallint(5) unsigned NOT NULL default '0', votetotal smallint(5) unsigned NOT NULL default '0', attach smallint(5) unsigned NOT NULL default '0', similar varchar(55) NOT NULL default '', PRIMARY KEY (threadid), UNIQUE KEY threadid (threadid), KEY postuserid (postuserid), KEY pollid (pollid), KEY forumid (forumid,visible,sticky,lastpost), KEY lastpost (lastpost,forumid) ) [/sql] |
#6
|
||||
|
||||
[sql]
SELECT MAX(threadid) AS threadid FROM thread; [/sql] |
#7
|
||||
|
||||
Yeah, that gives me the ID - but I need the whole record
|
#8
|
||||
|
||||
maybe
[sql] SELECT MAX(threadid) AS threadid, thread.x FROM thread; [/sql] |
#9
|
||||
|
||||
Does not work, as MAX() is a grouping function
|
#10
|
||||
|
||||
[sql]
SELECT MAX(threadid), title FROM thread; [/sql] Or maybe [sql] SELECT * FROM thread FORCE INDEX (indexname) ORDER BY threadid DESC LIMIT 1; [/sql] |
Thread Tools | |
Display Modes | |
|
|
X vBulletin 3.8.12 by vBS Debug Information | |
---|---|
|
|
More Information | |
Template Usage:
Phrase Groups Available:
|
Included Files:
Hooks Called:
|