啊? 又要洗数据啦!! 还是两个key决定一个表! 二维Map学习,基于guava的HashBasedTable

一个洗数据的需求,表设计的外建不能判断某一个数据源,还要根据tyoe来进行判断才可以。 那此时呆逼的查发能实现但不够优雅,于是乎想到了二维数组,查了下资料有相关的实现给大家分享下!!

背景

表设计如下:

通过map的话 就没办法很好的实现了,需要通过两个key 来确定一个 v 此时就想到了之前摸鱼看到过二维数组!!

不得不说 该摸鱼就得摸!

有了 HashBasedTable 就能很优雅的实现 取V的逻辑了!

HashBasedTable使用介绍

别忘记引入pom!

xml 复制代码
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
			<version>27.1-jre</version>
        </dependency>

代码!

typescript 复制代码
import com.google.common.collect.HashBasedTable;

public static void main(String[] args) {
        HashBasedTable<Integer, Integer, String> hashBasedTable = HashBasedTable
                .create();

        hashBasedTable.put(0, 1, "Hello Word");

        //判断row和column确定的二维点是否存在
        if(hashBasedTable.contains(0, 1)) {
            hashBasedTable.put(2, 3, "TEST1");
            hashBasedTable.put(2, 4, "TEST2");
        }

        //判断是否包含columnKey的值
        System.out.println("containsColumn -> " + hashBasedTable.containsColumn(3));
        //判断是否包含rowKey为0的视图
        System.out.println("containsRow ->" + hashBasedTable.containsRow(0));

        //获取row key为2的数据集
        Map<Integer, String> row = hashBasedTable.row(2);
        System.out.println("row ->" + JSONObject.toJSONString(row));

        //获取column为5的数据集
        Map<Integer, String> column = hashBasedTable.column(3);
        System.out.println("column ->" + JSONObject.toJSONString(column));

        //将table转换为Map套Map格式
        Map<Integer, Map<Integer, String>> rowMap = hashBasedTable.rowMap();
        System.out.println("rowMap ->" + JSONObject.toJSONString(rowMap));
        //获取所有的rowKey值的集合
        Set<Integer> keySet = hashBasedTable.rowKeySet();
        System.out.println("keySet -> " + JSONObject.toJSONString(keySet));

        System.out.println("hashBasedTable ->" + JSONObject.toJSONString(hashBasedTable));
    }

运行结果:

相关推荐
程序员泠零澪回家种桔子5 小时前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构
源代码•宸6 小时前
大厂技术岗面试之谈薪资
经验分享·后端·面试·职场和发展·golang·大厂·职级水平的薪资
晚霞的不甘6 小时前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
喵叔哟6 小时前
06-ASPNETCore-WebAPI开发
服务器·后端·c#
Charlie_lll7 小时前
力扣解题-移动零
后端·算法·leetcode
打工的小王8 小时前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
80530单词突击赢9 小时前
JavaWeb进阶:SpringBoot核心与Bean管理
java·spring boot·后端
爬山算法10 小时前
Hibernate(87)如何在安全测试中使用Hibernate?
java·后端·hibernate
WeiXiao_Hyy10 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
苏渡苇10 小时前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式