免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5494 | 回复: 7
打印 上一主题 下一主题

【讨论中】where子句中,有两个字段,两个字段都有索引,那查询时用的时那一个呢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-24 00:17 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2013-01-24 11:38 编辑

表结构如下:
  1. CREATE TABLE `testtime`
  2.   `name` varchar(20) DEFAULT NULL,
  3.   `time` datetime DEFAULT NULL,
  4.   KEY `index_name` (`name`),
  5.   KEY `time_index` (`time`)
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8
复制代码
用explain查看:
  1. mysql> explain select * from testtime where name = 'bill' or time > '2011-09-09'
  2. \G
  3. *************************** 1. row ***************************
  4.            id: 1
  5.   select_type: SIMPLE
  6.         table: testtime
  7.          type: ALL
  8. possible_keys: index_name,time_index
  9.           key: NULL
  10.       key_len: NULL
  11.           ref: NULL
  12.          rows: 3
  13.         Extra: Using where
  14. 1 row in set (0.00 sec)
复制代码
其中possible_keys: 有两个,,那到底会用那一个呢??

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
2 [报告]
发表于 2013-01-24 08:49 |只看该作者
你这数据少吧,mysql哪个都没用啊

论坛徽章:
0
3 [报告]
发表于 2013-01-24 10:01 |只看该作者
如果是or  ,mysql只会选择基中的一个索引,象你的例子,他肯定 会使用name字段的索引

由于你的数据较少,MySQL 可能认为全表扫描的代价比索引要小,所以,他会选择全表扫描 。

论坛徽章:
0
4 [报告]
发表于 2013-01-24 11:31 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
5 [报告]
发表于 2013-01-24 11:37 |只看该作者
原来mysql这么智能,还能根据行数来判断。学习学习。

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
6 [报告]
发表于 2013-01-24 11:38 |只看该作者
优化器会根据代价从possible key中选择一个key

论坛徽章:
8
综合交流区版块每周发帖之星
日期:2015-12-02 15:03:53数据库技术版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-09-14 06:20:00金牛座
日期:2014-10-10 11:23:34CU十二周年纪念徽章
日期:2013-10-24 15:41:34酉鸡
日期:2013-10-19 10:17:1315-16赛季CBA联赛之北京
日期:2017-03-06 15:12:44
7 [报告]
发表于 2013-01-24 13:16 |只看该作者
数据分布
possible key

论坛徽章:
0
8 [报告]
发表于 2013-01-24 16:11 |只看该作者
you also can specify index you prefer, e.g. using force index keyword
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP