MySQL Forums
Forum List  »  Performance

Re: speed up query
Posted by: Shabbir Ahmed
Date: May 02, 2010 03:54AM

today i made another replica of dsl_data table with only snrup and snrdown and look at the result, now what u sujjest! and the replica table has given this result without any indexing.

mysql> select count(snrdown) from dsl_data,dslam_ports where dslam_ports.dslam_id='2' and dsl_data.port_id=dslam_ports.id
-> and dsl_data.snrdown > 399;
+----------------+
| count(snrdown) |
+----------------+
| 31 |
+----------------+
1 row in set (43.21 sec)

mysql>
mysql>
mysql> select count(snrdown) from dsl_data_snr,dslam_ports where dslam_ports.dslam_id='2' and dsl_data_snr.port_id=dslam_ports.id
-> and dsl_data_snr.snrdown > 399
-> ;
+----------------+
| count(snrdown) |
+----------------+
| 31 |
+----------------+
1 row in set (13.29 sec)

mysql> show create table dsl_data;
+----------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+----------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| dsl_data | CREATE TABLE `dsl_data` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`port_id` int(11) DEFAULT NULL,
`snrup` decimal(5,2) DEFAULT NULL,
`snrdown` decimal(5,2) DEFAULT NULL,
`attnup` decimal(5,2) DEFAULT NULL,
`attndown` decimal(5,2) DEFAULT NULL,
`uprate` int(3) DEFAULT NULL,
`downrate` int(3) DEFAULT NULL,
`time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`),
KEY `id_dsl_data_time` (`time`),
KEY `idx_dsl_data_port_id` (`port_id`),
KEY `idx_dsl_data_time_portid` (`time`,`port_id`)
) ENGINE=InnoDB AUTO_INCREMENT=135872073 DEFAULT CHARSET=latin1 |
+----------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.01 sec)

mysql> show create table dsl_data_snr;
+--------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+--------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| dsl_data_snr | CREATE TABLE `dsl_data_snr` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`port_id` int(11) DEFAULT NULL,
`snrup` decimal(5,2) DEFAULT NULL,
`snrdown` decimal(5,2) DEFAULT NULL,
`time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=27131491 DEFAULT CHARSET=latin1 |
+--------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> select count(id) from dsl_data;
+-----------+
| count(id) |
+-----------+
| 27111939 |
+-----------+
1 row in set (3 min 7.39 sec)

mysql> select count(id) from dsl_data_snr;
+-----------+
| count(id) |
+-----------+
| 27111939 |
+-----------+
1 row in set (6.06 sec)



Edited 1 time(s). Last edit at 05/02/2010 04:02AM by Shabbir Ahmed.

Options: ReplyQuote


Subject
Views
Written By
Posted
4326
April 18, 2010 06:42AM
1609
April 18, 2010 04:04PM
1673
April 18, 2010 05:40PM
1414
April 27, 2010 02:29PM
1542
April 27, 2010 07:59PM
1408
April 28, 2010 12:12AM
1670
April 28, 2010 06:22AM
1612
April 29, 2010 01:03AM
1466
April 29, 2010 02:17AM
1487
April 29, 2010 08:19AM
1494
April 29, 2010 09:18AM
1397
April 30, 2010 12:30AM
1654
April 30, 2010 07:47AM
1575
April 30, 2010 08:21AM
1498
April 30, 2010 10:08AM
1407
May 01, 2010 02:34AM
1429
May 01, 2010 09:54AM
1374
May 01, 2010 10:48AM
1510
May 01, 2010 02:20PM
Re: speed up query
1451
May 02, 2010 03:54AM


Sorry, you can't reply to this topic. It has been closed.

Content reproduced on this site is the property of the respective copyright holders. It is not reviewed in advance by Oracle and does not necessarily represent the opinion of Oracle or any other party.