本文不对代码做深入了解,仅仅记录下相关的入口函数,便于以后工作遇到时能快速查阅。在最后附上了对应worklog的连接,感兴趣的朋友可以直接阅读worklog去了解他是如何实现的。

    摘录自官方文档

    通过如下三个函数member of, json_contains, json_overlaps可以使用到该索引

    multi-value index是functional index的一种实现,列的定义是一个虚拟列,值是从json column上取出来的数组 数组上存在相同值的话,会只存储一个到索引上。支持的类型:DECIMAL, INTEGER, DATETIME,VARCHAR/CHAR。另外index上只能有一个multi-value column。

    下面简单介绍下相关的接口函数

    插入记录: 入口函数 row_ins_sec_index_multi_value_entry 通过类Multi_value_entry_builder_insert来构建tuple, 然后调用正常的接口函数row_ins_sec_index_entry插入到二级索引中. 已经解析好,排序并去重的数据存储在结构struct multi_value_data , 指针在dfield_t::data中. multi_value_data结构也是multi-value具体值的内存表现

    删除记录: 入口函数: row_upd_del_multi_sec_index_entry 基于类Multi_value_entry_builder_normal构建tuple, 并依次从索引中删除

    更新记录 入口函数:row_upd_multi_sec_index_entry 由于可能不是所有的二级索引记录都需要更新,需要计算出diff,找出要更新的记录calc_row_difference –> innobase_get_multi_value_and_diff, 设置一个需要更新的bitmap

    事务回滚 相关函数:

    回滚的时候通过trx_undo_rec_get_multi_value从undo log中获取multi-value column的值,通过接口Multi_value_logger::read来构建并存储到field data中

    通过Multi_value_logger::log将multi-value的信息存储到Undo log中. ‘Multi_value_logger’是一个辅助类,用于记录multi-value column的值以及如何读出来

    purge 二级索引记录 入口函数:

    WL#8763: support multi-value functional index for InnoDB