Java 比较两个HashMap里的数据是否一致

开发中,可能会遇到两个HashMap内容的比较,如果一一去遍历比较的话,可能造成资源的浪费。现可以采用一下方法:

一.比较两个HashMap<String,TestBean> 内容是否一致

1.首先创建一个TestBean实体,记得重写hashCode  和  equals 方法。

package com.wxd.test;

public class TestBean {
	private String id = "";
	private String dc = "";
	private String status = "";
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public String getDc() {
		return dc;
	}
	public void setDc(String dc) {
		this.dc = dc;
	}
	public String getStatus() {
		return status;
	}
	public void setStatus(String status) {
		this.status = status;
	}
	@Override
	public String toString() {
		return "TestBean [id=" + id + ", dc=" + dc + ", status=" + status + "]";
	}
	public TestBean(String id, String dc, String status) {
		super();
		this.id = id;
		this.dc = dc;
		this.status = status;
	}
	public TestBean() {
		super();
		// TODO Auto-generated constructor stub
	}
	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((dc == null) ? 0 : dc.hashCode());
		result = prime * result + ((id == null) ? 0 : id.hashCode());
		result = prime * result + ((status == null) ? 0 : status.hashCode());
		return result;
	}
	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		TestBean other = (TestBean) obj;
		if (dc == null) {
			if (other.dc != null)
				return false;
		} else if (!dc.equals(other.dc))
			return false;
		if (id == null) {
			if (other.id != null)
				return false;
		} else if (!id.equals(other.id))
			return false;
		if (status == null) {
			if (other.status != null)
				return false;
		} else if (!status.equals(other.status))
			return false;
		return true;
	}
	
}
2.进行比较

	TestBean t1 = new TestBean("1", "1", "1");
	TestBean t2 = new TestBean("1", "1", "1");
	HashMap<String,TestBean> map1 = new HashMap();
	HashMap<String,TestBean> map2 = new HashMap();
	map1.put("1", t1);
	map2.put("1", t2);
	System.out.println(map1.equals(map2));
输出为 true

	TestBean t1 = new TestBean("1", "2", "1");
	TestBean t2 = new TestBean("1", "1", "1");
	HashMap<String,TestBean> map1 = new HashMap();
	HashMap<String,TestBean> map2 = new HashMap();
	map1.put("1", t1);
	map2.put("1", t2);
	System.out.println(map1.equals(map2));
输出为false

	TestBean t1 = new TestBean("1", "2", "1");
	TestBean t2 = new TestBean("1", "1", "1");
	TestBean t3 = new TestBean("1", "1", "1");
	
	HashMap<String,TestBean> map1 = new HashMap();
	HashMap<String,TestBean> map2 = new HashMap();
	map1.put("1", t1);
	map1.put("2", t3);
	map2.put("1", t2);
	System.out.println(map1.equals(map2));

输出为false


二、比较两个HashMap 中嵌套map

		HashMap<String,String> tmap1 =  new HashMap();
		HashMap<String,String> tmap2 =  new HashMap();
		tmap1.put("1", "1");
		tmap2.put("1", "1");
		tmap1.put("2", "1");
		HashMap<String,HashMap<String,String>> map1 = new HashMap();
		HashMap<String,HashMap<String,String>> map2 = new HashMap();
		map1.put("1", tmap1);
		map2.put("1", tmap2);
		System.out.println(map1.equals(map2));
输出为false

	HashMap<String,String> tmap1 =  new HashMap();
		HashMap<String,String> tmap2 =  new HashMap();
		tmap1.put("1", "1");
		tmap2.put("1", "1");
	//	tmap1.put("2", "1");
		HashMap<String,HashMap<String,String>> map1 = new HashMap();
		HashMap<String,HashMap<String,String>> map2 = new HashMap();
		map1.put("1", tmap1);
		map2.put("1", tmap2);
		System.out.println(map1.equals(map2));
输出为true

因为开发需要,只测试了这两种情况。

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用Java Database Connectivity(JDBC) API和SQL语句来比较两个数据库的表数据是否一致。以下是一个简单的示例: 1. 首先,使用JDBC连接到两个数据库。 2. 通过执行SELECT语句从第一个数据库中检索表数据,并将结果存储在List或HashMap中。 3. 通过执行SELECT语句从第二个数据库中检索表数据,并将结果存储在List或HashMap中。 4. 比较两个数据结构是否相同。如果两个数据库中的表数据相同,则这两个数据结构应该是一样的。 下面是一个示例代码: ```java import java.sql.*; import java.util.*; public class DatabaseComparator { private static String url1 = "jdbc:mysql://localhost:3306/database1"; private static String url2 = "jdbc:mysql://localhost:3306/database2"; private static String user = "username"; private static String password = "password"; public static void main(String[] args) { try { // Connect to first database Connection conn1 = DriverManager.getConnection(url1, user, password); Statement stmt1 = conn1.createStatement(); // Retrieve data from first database ResultSet rs1 = stmt1.executeQuery("SELECT * FROM table1"); List<Map<String, Object>> data1 = new ArrayList<>(); while (rs1.next()) { Map<String, Object> row = new HashMap<>(); row.put("column1", rs1.getObject("column1")); row.put("column2", rs1.getObject("column2")); data1.add(row); } // Connect to second database Connection conn2 = DriverManager.getConnection(url2, user, password); Statement stmt2 = conn2.createStatement(); // Retrieve data from second database ResultSet rs2 = stmt2.executeQuery("SELECT * FROM table1"); List<Map<String, Object>> data2 = new ArrayList<>(); while (rs2.next()) { Map<String, Object> row = new HashMap<>(); row.put("column1", rs2.getObject("column1")); row.put("column2", rs2.getObject("column2")); data2.add(row); } // Compare data from both databases if (data1.equals(data2)) { System.out.println("Table data is the same in both databases."); } else { System.out.println("Table data is different in both databases."); } // Close connections rs1.close(); stmt1.close(); conn1.close(); rs2.close(); stmt2.close(); conn2.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 请注意,此示例仅比较单个表中的数据。如果要比较多个表或整个数据库的数据,请编写相应的代码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值