登录
首页 >  数据库 >  MySQL

MySQL 8 JSON多值索引

来源:SegmentFault

时间:2023-02-24 07:41:10 421浏览 收藏

有志者,事竟成!如果你在学习数据库,那么本文《MySQL 8 JSON多值索引》,就很适合你!文章讲解的知识点主要包括MySQL、JSON、索引,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

MySQL 8 JSON多值索引

背景介绍

我们有个

ALTER TABLE `node`  
ADD INDEX `jump_node_code_index`( 
    (CAST(units_json -> '$.units[*].decisionEntries[*].capsules[*].jumpNodeCode' 
          AS CHAR(50) ARRAY)) 
);
上面那个
SELECT units_json -> '$.units[*].decisionEntries[*].capsules[*].jumpNodeCode' 
FROM   node;

条件查询

下面这个查询语句使用了

SELECT node_id, `code`, `name` FROM node
WHERE 'xxxNode' MEMBER OF (units_json -> '$.units[*].decisionEntries[*].capsules[*].jumpNodeCode');

编写jOOQ 工具类

我们项目的ORM框架使用jOOQ,国内相对MyBatis而言小众很多。但我比较喜欢用jOOQ,感兴趣的同学可自行谷歌。
jOOQ 没有提供MySQL这种比较复杂语法,于是自行封装了个工具类

public class JooqSyntax {  
    /**  
 * * @param value 检查值  
 * @param field 列  
 * @param jsonPath json文档语法  
 * @return jooq 条件  
 */  
 public static Condition memberOfCondition(Object value, TableField, ?> field, String jsonPath) {  
        return DSL.condition("{0} MEMBER OF ({1})", value, jsonField(field, jsonPath)  
        );  
 }  
  
    public static Field jsonField(TableField extends Record, ?> field, String jsonPath) {  
        return DSL.field("{0} -> {1}", field, jsonPath);  
 }  
}

单元测试,主要是用于说明如何使用。

public class JooqSyntaxTest {  
  
    @Test  
     void test() {  
        DSLContext ctx = DSL.using(SQLDialect.MYSQL);  
  
         Condition condition = JooqSyntax.memberOfCondition(1, TOPIC.PERMISSION_JSON, "$.xxx");  
     System.out.println(  
                ctx.selectFrom(TOPIC)  
                        .where(condition)  
        );  
  
     System.out.println(ctx  
                .select(JooqSyntax.jsonField(TOPIC.PERMISSION_JSON, "$.xxx"))  
                .from(TOPIC)  
        );  
 }  
}

相关参考:
MySQL 8.0 新特性:多值索引 --如何给JSON数组添加索引(三)
MySQL :: MySQL 8.0 Reference Manual :: 11.5 The JSON Data Type

今天关于《MySQL 8 JSON多值索引》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>