跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • MSYQL-取两个时间字段中的数据-索引如何建?
未分類
15 4 月 2021

MSYQL-取两个时间字段中的数据-索引如何建?

MSYQL-取两个时间字段中的数据-索引如何建?

資深大佬 : sue0917 0

如题,一张表中有一个开始时间字段 start_datetime,结束时间字段 end_datetime,
需求是取出当前时间大于开始时间,小于结束时间内的数据

索引应该如何建呢?

大佬有話說 (17)

  • 資深大佬 : chenhua19940128

    建一个 start_datetime 和 end_datetime 的联合索引?

  • 資深大佬 : zengxs

    两个字段分别建一个索引不就行了

  • 資深大佬 : beichenhpy

    联合索引,但是要注意顺序。。

  • 主 資深大佬 : sue0917

    @chenhua19940128
    @zengxs
    @beichenhpy

    联合索引或者分别建立索引感觉用处都非常有限啊,老哥们。。

    比如开始结束时间都在今天前的,和开始结束时间都在今天后的,分别有 200 万条数据。

    单独建开始时间或结束时间索引,都扫描出了 200 万条以上的主键 id 去回表?,基本是无效索引了。。
    搞个联合索引,好处可能是可以通过索引确实找到了主键 id 去回表,不过依然需要连续比对几百万条数据,开销依然很大

  • 資深大佬 : beichenhpy

    @sue0917 #4 数据太多确实无效索引。。应该加限制条件的吧。。

  • 主 資深大佬 : sue0917

    @beichenhpy 看看其他老哥们有方案没有,确实有点打脑壳。,。

  • 資深大佬 : beichenhpy

    @sue0917 #6 话说 int 类型字段的索引,not in 会走索引吗?我测了一下 type=range 。。网上都说不走索引。。range 好像也算走了索引吧

  • 資深大佬 : billlee

    换个思路,加个状态字段,然后用定时器维护这个字段

  • 主 資深大佬 : sue0917

    @billlee 状态字段定时器是种方式,不过不一定特别及时,万一定时器那一刻压力大了忙不过来,查出的数据就可能有误

    另外经常更新的字段做索引,不知道好不好。。想了下也还好,当做删除数据插入新数据了

  • 資深大佬 : lxd8023

    @sue0917 看具体的返回的字段吧,可以考虑利用索引覆盖的特性,一次性拉百万数据肯定要做分页限制。

  • 資深大佬 : RangerWolf

    @beichenhpy 我个人理解,是不是走索引要看成本优化器的预估。
    如果优化器发现需要扫描的数据非常多,比如超过 20% 或者 三分之一,类似这种,就不会走索引。
    你还可以试试看,比如网上经常说的 性别 字段的索引问题。 比如 10 条记录,1 个男的 9 个女的,查询条件分别测试 gender = m 与 gender != m
    在我的环境( MySQL 5.7 ) 索引的使用情况是不一样的

  • 主 資深大佬 : sue0917

    @lxd8023 返回一行全部字段,只拉取 10 条。
    但是抱歉我没有理解到你的意思,。

  • 資深大佬 : dongtingyue

    具体语句丢出来。筛选后数据有那么多你说会有啥办法,走索引只是说能减少时间而已。

  • 主 資深大佬 : sue0917

    @dongtingyue 关键是走不上索引,或者说没有找到合适的索引怎么建。,。
    现在就是来问问,索引怎么建才比较好。,。

  • 資深大佬 : Cy1

    @sue0917 除非索引覆盖,不然回表肯定是避免不了
    建联合索引,(start_datetime asc, end_datetime desc) 基本上数据分布就很符合你这个需求吧?
    这个顺序比对的次数应该不会比实际返回的行数大很多?

    如果优化器决定不走索引,你又想要用索引,那就自己手动标明使用的索引就行了。

  • 主 資深大佬 : sue0917

    @Cy1 查整行数据,回表是必然的,也没有想避免。而且我只查 10 条数据就行。

    问题像下面描述的,按照你这种方式建立索引,好像比对次数也有 200 万。。。。感觉不太合适
    比如开始结束时间都在今天前的,和开始结束时间都在今天后的,分别有 200 万条数据。

  • 資深大佬 : Cy1

    @sue0917 好像也是。。。 我再想想

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具