使用ORDER BY时如何减少sql查询时间

时间:2014-08-09 15:18:17

标签: mysql sql yii

我有一个使用yii framework开发的应用,其中一个查询耗时太长。如果没有criteria->order操作,它将在1秒内返回数据。

该表有100万注册。每列都有索引。查询是:

select *
 from village
 where map_type_id = 4 and status = 1
 order by last_update_resource asc
 limit 1

CREATE TABLE IF NOT EXISTS `village` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `x` int(11) NOT NULL DEFAULT '0',
  `y` int(11) NOT NULL DEFAULT '0',
  `k` int(11) NOT NULL DEFAULT '0',
  `map_type_id` int(11) NOT NULL,
  `village_type_id` int(11) NOT NULL,
  `name` varchar(30) NOT NULL,
  `user_id` int(11) NOT NULL DEFAULT '0',
  `nation_id` int(2) NOT NULL DEFAULT '0',
  `points` int(11) NOT NULL DEFAULT '0',
  `last_update` int(11) NOT NULL DEFAULT '0',
  `last_update_resource` int(11) NOT NULL,
  `verified` int(1) NOT NULL DEFAULT '0',
  `last_verification` int(11) NOT NULL,
  `last_update_points` int(11) NOT NULL DEFAULT '0',
  `status` int(11) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `x` (`x`),
  KEY `y` (`y`),
  KEY `k` (`k`),
  KEY `user_id` (`user_id`),
  KEY `nation_id` (`nation_id`),
  KEY `last_update_resource` (`last_update_resource`),
  KEY `map_type_id` (`map_type_id`),
  KEY `status` (`status`),
  KEY `village_type_id` (`village_type_id`),
  KEY `last_update` (`last_update`),
  KEY `verified` (`verified`),
  KEY `last_verification` (`last_verification`),
  KEY `name` (`name`),
  KEY `points` (`points`),
  KEY `last_update_points` (`last_update_points`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1000001 ;

如何将请求时间设置为1秒?

$criteria = new CDbCriteria();
$criteria->order = 'last_update_resource asc';
$criteria->limit = 1;

VillageSlaveM::$server_id = $world_id;
$model_village = VillageSlaveM::model()->findByAttributes(
        array(
    'map_type_id' => VillageM::$map_type_id['village'],
    'status' => VillageM::ACTIVE), $criteria
);

1 个答案:

答案 0 :(得分:3)

(map_type_id ,status,last_update_resource )上放置一个综合索引,以涵盖您所处的条件。

http://www.sqlfiddle.com/#!2/3bc6b/1