Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/68.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 使用ORDER BY时如何减少sql查询时间_Mysql_Sql_Yii - Fatal编程技术网

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

Mysql 使用ORDER BY时如何减少sql查询时间,mysql,sql,yii,Mysql,Sql,Yii,我使用yii框架开发了一个应用程序,其中一个查询耗时太长。如果没有条件->订单操作,它将在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

我使用
yii框架开发了一个应用程序
,其中一个查询耗时太长。如果没有
条件->订单
操作,它将在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
);

上放置一个综合索引(映射\u类型\u id、状态、上次更新\u资源)
以覆盖您的where条件


排序列上有索引吗?是的,我有13列,每列上都有索引。您能显示结果查询是什么吗?从MySQL的角度进行优化更容易。请向我们展示您的模式的SQLFIDLE,包括索引。这样行吗?