我有一个场景,需要将UI数据与数据库进行比较。
在UI中,我有n个数据和n个字段。
所以我想将所有n个数据和每个数据n个字段与数据库进行比较。
因此,对于我在嵌套映射中存储UI数据的方法,以及在嵌套映射中存储数据库数据的相同方式,现在我需要比较每条记录和记录的每个字段。有没有人能建议一下怎么做?
UI嵌套地图数据看起来像- {1={1=Edit,2=Click查看报表选项,3=123456},2={1=EMPTY,2=Click查看报表选项,3=6000792},3={1=EMPTY,2=Click查看报表选项,3=6000791}}
DB嵌套地图数据如下- {1={1=Edit,2=Click查看报表选项,3=123456},2={1=EMPTY,2=Click查看报表选项,3=6000792},3={1=EMPTY,2=Click查看报表选项,3=6000791},4={1=EMPTY,2=Click查看报表选项,3=6011791},5={1=EMPTY,2=Click查看报表选项,}}
我使用的是JAVA/WebDriver语言。由于我是java方面的新手,所以不确定如何实现这一点。请提个建议。
发布于 2017-01-27 22:57:47
我会使用谷歌的Guava library来做到这一点。该库提供了一个比较地图的方便方法:Maps.difference(mapA, mapB)
下面是示例(为简单起见,我将样本数据复制到两个ImmutableMap对象中。请注意,这当然也适用于“正常”贴图):
ImmutableMap<Integer, ImmutableMap<Integer, String>> uiMap = ImmutableMap.<Integer, ImmutableMap<Integer, String>>of(
1, ImmutableMap.<Integer, String>of(1, "Edit", 2, "Click to view report options", 3, "123456"),
2, ImmutableMap.<Integer, String>of(1, "EMPTY", 2, "Click to view report options", 3, "6000792"),
3, ImmutableMap.<Integer, String>of(1, "EMPTY", 2, "Click to view report options", 3, "6000791"));
ImmutableMap<Integer, ImmutableMap<Integer, String>> dbMap = ImmutableMap.<Integer, ImmutableMap<Integer, String>>of(
1, ImmutableMap.<Integer, String>of(1, "Edit", 2, "Click to view report options", 3, "123456"),
2, ImmutableMap.<Integer, String>of(1, "EMPTY", 2, "Click to view report options", 3, "6000792"),
3, ImmutableMap.<Integer, String>of(1, "EMPTY", 2, "Click to view report options", 3, "6000791"),
4, ImmutableMap.<Integer, String>of(1, "EMPTY", 2, "Click to view report options", 3, "6011791"),
5, ImmutableMap.<Integer, String>of(1, "EMPTY", 2, "Click to view report options", 3, "6011792"));
System.out.println(Maps.difference(uiMap, dbMap));这将为您提供以下输出:
not equal: only on right={4={1=EMPTY, 2=Click to view report options, 3=6011791}, 5={1=EMPTY, 2=Click to view report options, 3=6011792}}https://stackoverflow.com/questions/41880514
复制相似问题