java 通过Table进行多级别的查询

Table<String,String,String> table= HashBasedTable.create();
        //存放元素
        table.put("1001", "000000", "办公用品");
        table.put("1002", "000000", "自助终端设备");
        table.put("1003", "000000", "视频监控设备");
        table.put("1101", "1001", "打印机");

        //取出元素
        String dayCount = table.get("1001", "000000");
    
        System.out.println(table.contains("10021", "000000")+"----取出元素---"+dayCount);

 //{1=[000000=map, 000001=map]}
        HashMultimap<String, String> map = HashMultimap.create();
        String str="000000=map";
        String input = "John=first,Adam=second";
        Map<String, String> result = Splitter.on(",")
                .withKeyValueSeparator("=")
                .split(input);
        map.put("1",str);
        String str1="000001=map";
        map.put("1",str1);
        System.out.println(map+"================================"+result.get("John"));

list转map

List<String> names = Lists.newArrayList("John", "Jane", "Adam", "Tom");
String result = Joiner.on(",").join(names);
	 
assertEquals(result, "John,Jane,Adam,Tom");

String–>List

String input = "apple - banana - orange";
List<String> result = Splitter.on("-").trimResults().splitToList(input);

Map–>String

      String to List/Map Splitter
      List/Map to String Joiner
      Map<String, Integer> salary = Maps.newHashMap();
      	    salary.put("John", 1000);
      	    salary.put("Jane", 1500);
      	    String result = Joiner.on(" , ").withKeyValueSeparator(" = ")
      	                                    .join(salary);

分组

import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class Demo2 {
    public static void main(String[] args) {
        DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
        // data list
        List<User> userList = Arrays.asList(
                User.builder().id(123456).name("Zhang, San").city("ShangHai").sex("man").birthDay(LocalDateTime.parse("2022-07-01 12:00:00", df)).build(),
                User.builder().id(777777).name("Zhang, San").city("ShangHai").sex("woman").birthDay(LocalDateTime.parse("2022-07-01 12:00:00", df)).build(),
                User.builder().id(888888).name("Li, Si").city("ShangHai").sex("man").birthDay(LocalDateTime.parse("2022-07-01 12:00:00", df)).build(),
                User.builder().id(999999).name("Zhan, San").city("HangZhou").sex("woman").birthDay(LocalDateTime.parse("2022-07-01 12:00:00", df)).build(),
                User.builder().id(555555).name("Li, Si").city("NaJin").sex("man").birthDay(LocalDateTime.parse("2022-07-01 12:00:00", df)).build()
        );
        Map<String, List<User>> groupMap = userList.stream()
        	.collect(Collectors.groupingBy(User::getCity));
        groupMap.forEach((k, v) -> {
            System.out.println(k);
            System.out.println(v);
        });
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值