第十三章 广告检索系统——监听 Binlog 构造增量索引(二)

此博客用于个人学习,来源于网上,对知识点进行一个整理。

1. 根据 Binlog 对象构造增量数据:

接下来利用 Binlog 对象去构造增量数据,然后将增量数据投递出去,构建增量索引。在构建增量数据之前,先去做一些准备工作。因为我们将 Binlog 解析出来的对象看起来还是比较复杂,里面一些元素对于投递工作去构建增量索引是不需要的。所以我们需要对这个对象进行简化。

1.1 准备工作:

@Data
@NoArgsConstructor
@AllArgsConstructor
public class MySqlRowData {
   
    //数据库名
    private String tableName;
    //数据表的层级
    private String level;
    //定义的操作数据类型
    private OpType opType;

    private List<Map<String, String>> fieldValueMap = new ArrayList<>();
}

在 OpType 中实现将 EventType 类型转化为 OpType 类型的方法:

/**
 * EventType 到 OpType 数据的转换
 * @param eventType
 * @return
 */
public static OpType to(EventType eventType){
   
    switch (eventType){
   
        case EXT_WRITE_ROWS:
            return ADD;
        case EXT_UPDATE_ROWS:
            return UPDATE;
        case EXT_DELETE_ROWS:
            return DELETE;
        default:
            return OTHER;
    }
}

定义一个类 Constant 实现对表的定义以及定义表需要解析的各个列。

public class Constant {
   

    private static final String DB_NAME = "imooc_ad_data";

    public static class AD_PLAN_TABLE_INFO {
   

        public static final String TABLE_NAME = "ad_plan";

        public static final String COLUMN_ID = "id";
        public static final String COLUMN_USER_ID = "user_id";
        public static final String COLUMN_PLAN_STATUS = "plan_status";
        public static final String COLUMN_START_DATE = "start_date";
        public static final String COLUMN_END_DATE = "end_date";
    }

    public static class AD_CREATIVE_TABLE_INFO {
   

        public static final String TABLE_NAME = "ad_creative";

        public static final String COLUMN_ID = "id";
        public static final String COLUMN_TYPE = "type";
        public static final String COLUMN_MATERIAL_TYPE = "material_type";
        public static final String COLUMN_HEIGHT = "height";
        public static final String COLUMN_WIDTH = "width";
        public static final String COLUMN_AUDIT_STATUS = "audit_status";
        public static final String COLUMN_URL = "url";
    }

    public 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值