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,包括索引。这样行吗?